中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

php中mysql連接方式PDO使用詳解
來源:易賢網 閱讀:16690 次 日期:2015-02-27 10:26:45
溫馨提示:易賢網小編為您整理了“php中mysql連接方式PDO使用詳解”,方便廣大網友查閱!

本文主要詳細介紹了PHP中mysql的連接方式PDO的各種使用方法,算是個人的一個小結,如有遺漏還請告之,有需要的小伙伴來參考下吧。

PDO常用方法:

PDO::query()主要用于有記錄結果返回的操作(PDOStatement),特別是select操作。

PDO::exec()主要是針對沒有結果集合返回的操作。如insert,update等操作。返回影響行數。

PDO::lastInsertId()返回上次插入操作最后一條ID,但要注意:如果用insert into tb(col1,col2) values(v1,v2),(v11,v22)..的方式一次插入多條記錄,lastinsertid()返回的只是第一條(v1,v2)插入時的ID,而不是最后一條記錄插入的記錄ID。

PDOStatement::fetch()是用來獲取一條記錄。配合while來遍歷。

PDOStatement::fetchAll()是獲取所有記錄集到一個中。

PDOStatement::fetchcolumn([int column_indexnum])用于直接訪問列,參數column_indexnum是該列在行中的從0開始索引值,但是,這個方法一次只能取得同一行的一列,只要執行一次,就跳到下一行。因此,用于直接訪問某一列時較好用,但要遍歷多列就用不上。

PDOStatement::rowcount()適用于當用query("select ...")方法時,獲取記錄的條數。也可以用于預處理中。$stmt->rowcount();

PDOStatement::columncount()適用于當用query("select ...")方法時,獲取記錄的列數。

注解:

1、選fetch還是fetchall?

小記錄集時,用fetchall效率高,減少從數據庫檢索次數,但對于大結果集,用fetchall則給系統帶來很大負擔。數據庫要向WEB前端傳輸量太大反而效率低。

2、fetch()或fetchall()有幾個參數:

mixed pdostatement::fetch([int fetch_style [,int cursor_orientation [,int cursor_offset]]])

array pdostatement::fetchAll(int fetch_style)

fetch_style參數:

■$row=$rs->fetchAll(PDO::FETCH_BOTH); FETCH_BOTH是默認的,可省,返回關聯和索引。

■$row=$rs->fetchAll(PDO::FETCH_ASSOC); FETCH_ASSOC參數決定返回的只有關聯數組。

■$row=$rs->fetchAll(PDO::FETCH_NUM); 返回索引數組

■$row=$rs->fetchAll(PDO::FETCH_OBJ); 如果fetch()則返回對象,如果是fetchall(),返回由對象組成的二維數組

代碼如下:

<?php

$dbh = new PDO('mysql:host=localhost;dbname=access_control', 'root', '');

$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

$dbh->exec('set names utf8');

/*添加*/

//$sql = "INSERT INTO `user` SET `login`=:login AND `password`=:password";

$sql = "INSERT INTO `user` (`login` ,`password`)VALUES (:login, :password)"; $stmt = $dbh->prepare($sql); $stmt->execute(array(':login'=>'kevin2',':password'=>''));

echo $dbh->lastinsertid();

/*修改*/

$sql = "UPDATE `user` SET `password`=:password WHERE `user_id`=:userId";

$stmt = $dbh->prepare($sql);

$stmt->execute(array(':userId'=>'7', ':password'=>'4607e782c4d86fd5364d7e4508bb10d9'));

echo $stmt->rowCount();

/*刪除*/

$sql = "DELETE FROM `user` WHERE `login` LIKE 'kevin_'"; //kevin%

$stmt = $dbh->prepare($sql);

$stmt->execute();

echo $stmt->rowCount();

/*查詢*/

$login = 'kevin%';

$sql = "SELECT * FROM `user` WHERE `login` LIKE :login";

$stmt = $dbh->prepare($sql);

$stmt->execute(array(':login'=>$login));

while($row = $stmt->fetch(PDO::FETCH_ASSOC)){

print_r($row);

}

print_r( $stmt->fetchAll(PDO::FETCH_ASSOC));

?>

1 建立連接

代碼如下:

<?php

$dbh=newPDO('mysql:host=localhost;port=3306; dbname=test',$user,$pass,array(

PDO::ATTR_PERSISTENT=>true

));

?>

持久性鏈接PDO::ATTR_PERSISTENT=>true

2. 捕捉錯誤

代碼如下:

<?php

try{

$dbh=newPDO('mysql:host=localhost;dbname=test',$user,$pass);

$dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);

$dbh->exec("SET CHARACTER SET utf8");

$dbh=null; //斷開連接

}catch(PDOException$e){

print"Error!:".$e->getMessage()."<br/>";

die();

}

?>

3. 事務的

代碼如下:

<?php

try{

$dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);

$dbh->beginTransaction();//開啟事務

$dbh->exec("insertintostaff(id,first,last)values(23,'Joe','Bloggs')");

$dbh->exec("insertintosalarychange(id,amount,changedate)

values(23,50000,NOW())");

$dbh->commit();//提交事務

}catch(Exception$e){

$dbh->rollBack();//錯誤回滾

echo"Failed:".$e->getMessage();

}

?>

4. 錯誤處理

a. 靜默模式(默認模式)

代碼如下:

$dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_SILENT); //不顯示錯誤

$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);//顯示警告錯誤,并繼續執行

$dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);//產生致命錯誤,PDOException

代碼如下:

<?php

try{

$dbh = new PDO($dsn, $user, $password);

$sql = 'Select * from city where CountryCode =:country';

$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);

$stmt = $dbh->prepare($sql);

$stmt->bindParam(':country', $country, PDO::PARAM_STR);

$stmt->execute();

while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {

print $row['Name'] . "/t";

}

} // if there is a problem we can handle it here

catch (PDOException $e) {

echo 'PDO Exception Caught. ';

echo 'Error with the database: <br />';

echo 'SQL Query: ', $sql;

echo 'Error: ' . $e->getMessage();

}

?>

1. 使用 query()

代碼如下:

<?php

$dbh->query($sql); 當$sql 中變量可以用$dbh->quote($params); //轉義字符串的數據

$sql = 'Select * from city where CountryCode ='.$dbh->quote($country);

foreach ($dbh->query($sql) as $row) {

print $row['Name'] . "/t";

print $row['CountryCode'] . "/t";

print $row['Population'] . "/n";

}

?>

2. 使用 prepare, bindParam和 execute [建議用,同時可以用添加、修改、刪除]

代碼如下:

<?php

$dbh->prepare($sql); 產生了個PDOStatement對象

PDOStatement->bindParam()

PDOStatement->execute();//可以在這里放綁定的相應變量

?>

3. 事物

代碼如下:

<?php

try {

$dbh = new PDO('mysql:host=localhost;dbname=test', 'root', '');

$dbh->query('set names utf8;');

$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

$dbh->beginTransaction();

$dbh->exec("Insert INTO `test`.`table` (`name` ,`age`)VALUES ('mick', 22);");

$dbh->exec("Insert INTO `test`.`table` (`name` ,`age`)VALUES ('lily', 29);");

$dbh->exec("Insert INTO `test`.`table` (`name` ,`age`)VALUES ('susan', 21);");

$dbh->commit();

} catch (Exception $e) {

$dbh->rollBack();

echo "Failed: " . $e->getMessage();

}

?>

以上就是關于PHP中pdo的相關用法的全部內容了,希望本文能對大家有所幫助,也希望大家能夠喜歡。

更多信息請查看IT技術專欄

更多信息請查看網絡編程
易賢網手機網站地址:php中mysql連接方式PDO使用詳解
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
欧美激情综合五月色丁香| 欧美日韩国产在线| 99综合电影在线视频| a91a精品视频在线观看| 亚洲图片欧美午夜| 久久午夜视频| 欧美色区777第一页| 国产精品亚洲片夜色在线| 国内揄拍国内精品少妇国语| 亚洲欧洲精品一区二区| 亚洲欧美在线免费观看| 欧美久久久久久久久久| 国产亚洲激情在线| 中文在线一区| 久久综合久久久| 国产欧美日韩亚州综合| 亚洲免费av电影| 老牛嫩草一区二区三区日本| 国产精品色婷婷久久58| 日韩视频一区| 免费一级欧美片在线观看| 国产视频一区二区三区在线观看| 一本久道久久综合狠狠爱| 欧美顶级艳妇交换群宴| 亚洲第一天堂av| 美女精品在线观看| 亚洲第一精品福利| 美女主播一区| 狠狠噜噜久久| 久久亚洲精品一区| 国产一区二区三区四区在线观看 | 欧美日韩色婷婷| 亚洲高清视频在线| 久久综合婷婷| 1024精品一区二区三区| 久久精品亚洲一区| 国产亚洲美州欧州综合国| 欧美一级成年大片在线观看| 国产精品美女在线| 亚洲自拍三区| 国产精品欧美精品| 亚洲免费综合| 国产主播在线一区| 女同一区二区| 99re6这里只有精品视频在线观看| 欧美激情1区| 亚洲图片欧美午夜| 国产精品综合| 麻豆国产精品一区二区三区| 亚洲激情成人在线| 欧美日韩亚洲一区二区三区四区| 一区二区三区欧美在线| 国产精品亚洲成人| 久久天天躁狠狠躁夜夜av| 亚洲欧洲综合另类在线| 欧美日韩一区在线观看| 亚洲欧美成人| 永久免费精品影视网站| 欧美人体xx| 欧美淫片网站| 亚洲国产成人在线播放| 欧美日韩成人综合天天影院| 国产精品99久久久久久宅男| 国产伦精品一区二区三区高清| 久久久久久久97| 一本色道久久加勒比精品| 国产精品美女久久久久久久| 久久亚裔精品欧美| 中文网丁香综合网| 国产一区二区三区的电影| 蜜桃av一区二区三区| 在线亚洲欧美专区二区| 好看的日韩视频| 国产精品大片免费观看| 久久视频免费观看| 在线视频免费在线观看一区二区| 国产一区二区精品丝袜| 欧美日韩一区二区三区在线看| 久久成人在线| 亚洲男女毛片无遮挡| 亚洲精品国产系列| 一区二区三区在线不卡| 国产精品美女久久久久久久| 欧美成人精品| 久久婷婷国产综合国色天香| 性做久久久久久久久| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 欧美精品v国产精品v日韩精品| 午夜在线观看免费一区| 亚洲精品日韩综合观看成人91| 国产一区二区看久久| 国产精品色网| 国产精品成人一区二区艾草| 欧美精品一区二区三区久久久竹菊| 久久精品国产91精品亚洲| 亚洲永久视频| 亚洲欧美日韩国产综合在线| 一本久久综合亚洲鲁鲁五月天| 亚洲高清不卡在线| 亚洲国产婷婷香蕉久久久久久| 狠狠入ady亚洲精品| 激情偷拍久久| 亚洲福利av| 亚洲欧洲一区二区三区在线观看| 伊人久久大香线| 亚洲国产高清在线观看视频| 精品不卡在线| 亚洲电影有码| 亚洲理论在线观看| 一区二区日韩免费看| 一区二区电影免费观看| 99热精品在线观看| 亚洲一区二区三区国产| 亚洲女女做受ⅹxx高潮| 午夜免费久久久久| 欧美一级淫片播放口| 欧美在线观看你懂的| 久久乐国产精品| 免费成人高清| 欧美日韩在线高清| 国产精品超碰97尤物18| 国产精品亚洲精品| 国一区二区在线观看| 亚洲激情电影在线| 99精品久久久| 一区二区三区四区五区视频| 亚洲一区二区三区精品动漫| 久久国内精品视频| 欧美激情一区二区三区在线视频观看 | 久久成人免费电影| 久久综合电影| 欧美顶级少妇做爰| 欧美涩涩视频| 国产女人精品视频| 在线欧美日韩国产| 亚洲精品视频免费| 亚洲影院免费| 久久综合福利| 欧美日韩直播| 韩国av一区二区| 夜夜夜精品看看| 久久午夜国产精品| 欧美日韩综合在线| 黄色一区二区在线观看| 99精品国产99久久久久久福利| 亚洲欧美怡红院| 欧美激情国产日韩精品一区18| 国产精品毛片大码女人| 亚洲东热激情| 欧美亚洲在线| 欧美日韩国产首页| 今天的高清视频免费播放成人| 日韩一级不卡| 久久一区激情| 国产亚洲高清视频| 一区二区三区你懂的| 噜噜噜噜噜久久久久久91| 国产农村妇女精品| 一本高清dvd不卡在线观看| 久久久av水蜜桃| 国产精品视频精品视频| 亚洲人午夜精品免费| 久久爱www.| 国产精品美女视频网站| 亚洲另类在线视频| 麻豆精品网站| 经典三级久久| 久久视频这里只有精品| 国产精品久久久久久久久久尿| 91久久精品美女| 久久午夜精品一区二区| 国产一区二区三区高清播放| 亚洲小视频在线观看| 欧美日韩在线播| 一卡二卡3卡四卡高清精品视频| 久久在线免费| 在线观看精品| 卡通动漫国产精品| 精品不卡在线| 欧美成人一区二区在线| 亚洲高清激情| 欧美精品一区二区视频| 亚洲伦理久久| 欧美揉bbbbb揉bbbbb| 99成人免费视频| 欧美性猛交一区二区三区精品| 亚洲精品国产拍免费91在线| 久久人人97超碰国产公开结果| 国产欧美欧美| 久久激情五月激情| 国产日韩欧美高清| 久久成人18免费网站| 国产最新精品精品你懂的| 久久精品视频va| 樱桃视频在线观看一区| 欧美成人高清视频| 99这里只有精品| 欧美日韩一区在线播放| 亚洲一区综合| 黄色国产精品|