国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

PHP mysqli操作數據庫

2020-03-22 16:33:28
字體:
來源:轉載
供稿:網友
起步

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

使用mysqli有面向過程和html' target='_blank'>面向對象兩種方式。

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;//插入的idecho $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 多次插入為最后idecho $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操作數據庫的詳細內容,更多請關注 其它相關文章!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 华宁县| 阳春市| 德格县| 隆回县| 大方县| 清河县| 长汀县| 娄烦县| 龙陵县| 榆社县| 慈利县| 鞍山市| 越西县| 礼泉县| 南京市| 永修县| 东源县| 驻马店市| 乌鲁木齐县| 金秀| 饶阳县| 章丘市| 巩义市| 敖汉旗| 历史| 南投县| 靖远县| 盐津县| 开原市| 旬邑县| 铁岭县| 政和县| 渑池县| 调兵山市| 三穗县| 皮山县| 托克逊县| 昌都县| 丹巴县| 泗洪县| 榆社县|