由於mysql連線方式被廢除,在php7中要使用mysql_connect()還需要額外下載元件。
使用mysqli有程序導向和物件導向兩種方式。
mysqli提供了三個類:
● mysqli 連線相關的
● mysqli_result 處理結果集
● 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語句執行成功了。
<?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是預處理類
<?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();
更多的PHP相關知識,請存取PHP中文網!
以上就是PHP mysqli運算元據庫的詳細內容,更多請關注TW511.COM其它相關文章!