首頁 >後端開發 >php教程 >PHP mysqli操作資料庫

PHP mysqli操作資料庫

藏色散人
藏色散人轉載
2019-11-07 13:54:421960瀏覽

開始

由於mysql連接方式被廢除,在php7中要使用mysql_connect()還需要額外下載元件。

使用mysqli有面向過程和物件導向兩種方式。

mysqli提供了三個類別:

● mysqli 連結相關的

● mysqli_result 處理結果集

# mysqli_stmt 預處理類別

資料庫連線

<?php
$db_host = &#39;localhost&#39;;
$db_name = &#39;test&#39;;
$db_user = &#39;root&#39;;
$db_pwd = &#39;&#39;;
//面向对象方式
$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 &#39;utf8&#39;")
//关闭连接
$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語句執行成功了。

<?php
//无结果集示例
$sql = "insert into table_name (`name`, `address`) values (&#39;xiaoming&#39;, &#39;adddddrrreess&#39;)";
$result = $mysqli->query($sql);
//或者
$sql = "delete from table_name where name=&#39;xiaoming&#39;";
$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[&#39;name&#39;];
    echo $row[&#39;address&#39;];
}
//也可一次性获取所有数据
//$result->data_seek(0);//如果前面有移动指针则需重置
$data = $result->fetch_all(MYSQLI_ASSOC);
$mysqli->close();

預處理範例

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

<?php
$sql = "insert inro table_name (&#39;name&#39;,&#39;address&#39;) 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 (&#39;xiaoming&#39;,&#39;a&#39;)",
    "insert into table_name (`name`,`address`) values (&#39;xiaohong&#39;,&#39;a&#39;)",
    &#39;delete from table_name where id=23&#39;,
);
$sql = implode(&#39;;&#39;, $sql_arr);
$result = $mysqli->multi_query($sql);
if($result === false){
    echo $mysqli->error;
}
$mysqli->close();

更多的PHP相關知識,請造訪PHP中文網

以上是PHP mysqli操作資料庫的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:segmentfault.com。如有侵權,請聯絡admin@php.cn刪除