PHP mysqli 操做數據庫

起步


因爲mysql鏈接方式被廢除,聽說在php7中要使用mysql_connect()還須要額外下載組件。
使用mysqli有面向過程和麪向對象兩種方式。
mysqli提供了三個類:php

  1. mysqli 鏈接相關的mysql

  2. mysqli_result 處理結果集sql

  3. mysqli_stmt 預處理類數據庫

數據庫鏈接

<?php
$db_host = 'localhost';
$db_name = 'test';
$db_user = 'root';
$db_pwd = '';

//面向對象方式
$mysqli = new mysqli($db_host, $db_user, $db_pwd, $db_name);
//面向對象的昂視屏蔽了鏈接產生的錯誤,須要經過函數來判斷
if(mysqli_connect_error()){
    echo mysqli_connect_error();
}
//設置編碼
$mysqli->set_charset("utf8");//或者 $mysqli->query("set names 'utf8'")
//關閉鏈接
$mysqli->close();

//面向過程方式的鏈接方式

$mysqli = mysqli_connect($db_host, $db_user, $db_pwd, $db_name);
//判斷是否鏈接成功
if(!$mysqli ){
    echo mysqli_connect_error();
}
//關閉鏈接
mysqli_close($mysqli);
?>

數據庫查詢

通用:執行sql語句均可用query(sql),執行失敗會返回false,select成功則返回結果集對象,其餘返回true,只要不是false就說明sql語句執行成功了。php7

<?php
//無結果集示例
$sql = "insert into table_name (`name`, `address`) values ('xiaoming', 'adddddrrreess')";
$result = $mysqli->query($sql);
//或者
$sql = "delete from table_name where name='xiaoming'";
$result = $mysqli->query($sql);

if($result === false){
    echo $mysqli->error;
    echo $mysqli->errno;
}
//影響條數
echo $mysqli->num_rows;
//插入的id
echo $mysqli->insert_id;
$mysqli->close();

有結果集函數

<?php
$sql = "select * from table_name";
$result = $mysqli->query($sql);
if($result === false){//執行失敗
    echo $mysqli->error;
    echo $mysqli->errno;
}
//行數
echo $result->num_rows;
//列數 字段數
echo $result->field_count;
//獲取字段信息
$field_info_arr = $result->fetch_fields();
//移動記錄指針
//$result->data_seek(1);//0 爲重置指針到起始
//獲取數據
while($row = $result->fetch_assoc()){
    echo $row['name'];
    echo $row['address'];
}
//也可一次性獲取全部數據
//$result->data_seek(0);//若是前面有移動指針則需重置
$data = $result->fetch_all(MYSQLI_ASSOC);
$mysqli->close();

預處理示例

預處理能有效的防止sql注入的產生,mysqli_stmt是預處理類fetch

<?php
$sql = "insert inro table_name ('name','address') values (?,?)";
//得到預處理對象
$stmt = $mysqli->prepare($sql);
//綁定參數 第一個參數爲綁定的數據類型
/*
i:integer 整型
d:double 浮點型
s:string 字符串
b:a blob packets blob數據包
*/
$name = "xiaoming";
$address = "adddressss";
$stmt->bind_param("ss", $name, $address);//綁定時使用變量綁定
//執行預處理
$stmt->execute();
/*
//可從新綁定 屢次執行
$stmt->bind_param("ss", $name, $address);
$stmt->execute();
*/
//插入的id 屢次插入爲最後id
echo $stmt->insert_id;
//影響行數 也是最後一次執行的
echo $stmt->affected_rows;
//錯誤號
echo $stmt->errno;
//錯誤信息
echo $stmt->error;
//關閉
$stmt->close();
$mysqli->close();

下面示例select的預處理編碼

//註釋部分省略
$sql = "select * from table_name where id<?";
$stmt = $mysqli->prepare($sql);
$id = 30;
$stmt->bind_param("i", $id);
$stmt->execute();
//獲取結果集
$result = $stmt->get_result();//結果集取後的操做就和以前同樣了
//獲取全部數據
$data = $result->fetch_all(MYSQLI_ASSOC);
$result->close();
$mysqli->close();

一次執行多條sql語句multiquery(不推薦),執行結果不是結果集,affectd_rows是最後影響的條數指針

<?php
$sql_arr = array(
    "insert into table_name (`name`,`address`) values ('xiaoming','a')",
    "insert into table_name (`name`,`address`) values ('xiaohong','a')",
    'delete from table_name where id=23',
);
$sql = implode(';', $sql_arr);
$result = $mysqli->multi_query($sql);
if($result === false){
    echo $mysqli->error;
}
$mysqli->close();
相關文章
相關標籤/搜索