第14章pdo數據庫抽象層_第1頁
第14章pdo數據庫抽象層_第2頁
第14章pdo數據庫抽象層_第3頁
第14章pdo數據庫抽象層_第4頁
第14章pdo數據庫抽象層_第5頁
已閱讀5頁,還剩66頁未讀 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

第14章PDO數據庫抽象層14.1PDO概述14.2PDO連接數據庫14.3在PDO中執行SQL語句14.4PDO獲取結果集14.5PDO錯誤處理14.6PDO捕獲SQL語句中的錯誤14.7PDO事務處理14.8綜合實訓案例第14章PDO數據庫抽象層學習目的與要求掌握PHP數據庫編程總體步驟掌握PDO連接數據庫的方法掌握在PDO中執行SQL語句的方法

掌握在PHP網頁中顯示數據表的數據的方法理解捕獲SQL語句中的錯誤PHP數據庫編程總體步驟①

連接數據庫②

執行SQL語句③

獲取結果集④

顯示結果集例如:$pdo=newPDO($dsn,$user,$password);例如:$rows=$pdo->query($sql);例如:$row=$rows->fetch(PDO::FETCH_OBJ)例如:print_r($row)PHP數據庫編程步驟show_books.php①

show_books.php<?php$user="root";$password="";//連接數據庫的用戶名、密碼

$host="localhost";$db_name="bookmanage";//數據庫服務器地址、數據庫名稱

$dsn="mysql:host=$host;dbname=$db_name";//數據源名稱

try{$pdo=newPDO($dsn,$user,$password);//實例化對象

$pdo->query("setnamesutf8");$sql="select*frombook";$rows=$pdo->query($sql); echo"<tableborder=5bordercolor='#999999'> <tr><td>圖書編號</td><td>圖書名稱</td><td>作者</td></tr>"; while($row=$rows->fetch(PDO::FETCH_OBJ)){ echo"<tr>"; echo"<td>",$row->bookid,"</td>"; echo"<td>",$row->bookname,"</td>";echo"<td>",$row->editor,"</td>"; echo"</tr>"; } echo"</table>";}catch(Exception$e)//捕捉錯誤信息

{echo$e->getMessage();}?>14.1

PDO概述14.1.1

PDO的概念及特點1.PDO的概念PDO是PHPDataObject(PHP數據對象)的簡稱,是PHP5.1之后發布的一個全新的數據庫連接層,它支持目前流行的絕大多數數據庫,例如MySQL、MSSQLServer、Oracle、Sybase等。PDO出現后,PHP程序連接數據庫就不再使用mysqli_*函數、oci_*函數或者mssql_*函數了,只需要使用PDO接口中的方法就可輕松地連接數據庫,而且只需要修改PDO的DSN(數據源名稱)就可以連接不同類型的數據庫。14.1

PDO概述14.1.1

PDO的概念及特點2.PDO的特點PDO的作用就是統一各種數據庫的訪問接口,這樣可以輕松地與各種數據庫進行交互,使得PHP操作各種不同類型的數據庫更加方便和高效。PDO擴展是模塊化的,用戶在運行時,只需要為數據庫加載驅動程序即可,不需要重新編譯和安裝PHP系統。14.1.2PDO的配置PDO是隨著PHP系統一起發行的,默認情況下,PDO在PHP系統中為開啟狀態。如果要啟用對某個數據庫驅動程序的支持,就要打開php.ini文件進行相應的配置。PDO的配置選項如圖所示。要檢測PHP系統中PDO是否已經啟動,可以編寫一個PHP程序,寫入語句:

<?php

phpinfo();?>

該PHP程序文件啟動后,若能找到PDO的信息內容,就說明PDO已經啟動。進一步?----增加記錄將show_books.php命名為show_books_insert.php在show_books_insert.php中用SQL語句往book表中增加”大學英語”的圖書信息,并把所有信息展示出來(數據參看P135示例8-14的結果)進一步??----利用界面增加記錄設計一個添加圖書信息的界面的insert_html.php網頁結合show_books_insert.php中用SQL語句往book表中增加”高等數學”的圖書信息并把所有信息展示出來(數據參看P135示例8-14的結果)insert_html.php網頁insert_html.php代碼<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"""><htmlxmlns=""><head><metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/><title>增加記錄</title></head><body><formmethod="post"action="show_books_insert.php">圖書編號:<inputtype="text"name="bookid"/><br/>圖書名稱:<inputtype="text"name="bookname"/><br/>作者:<inputtype="text"name="editor"/><br/><inputtype="submit"name="ok"value="增加"/><br/></form></body></html>show_books_insert.php網頁show_books_insert.php代碼<html><head><metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/><title>圖書清單</title></head><body><?php$bookid=$_POST["bookid"];$bookname=$_POST["bookname"];$editor=$_POST["editor"];

$user="root";$password="";//連接數據庫的用戶名、密碼

$host="localhost";$db_name="bookmanage";//數據庫服務器地址、數據庫名稱

$dsn="mysql:host=$host;dbname=$db_name";//數據源名稱

try{$pdo=newPDO($dsn,$user,$password);//實例化對象

$pdo->query("setnamesutf8"); $insert_row_count=$pdo->exec('INSERTINTO`book`(`bookid`,`bookname`,`editor`)VALUES("'.$bookid.'","'.$bookname.'","'.$editor.'")'); $sql="select*frombook";$rows=$pdo->query($sql); echo"<tableborder=5bordercolor='#999999'> <tr><td>圖書編號</td><td>圖書名稱</td><td>作者</td></tr>"; while($row=$rows->fetch(PDO::FETCH_OBJ)){ echo"<tr>"; echo"<td>",$row->bookid,"</td>"; echo"<td>",$row->bookname,"</td>";echo"<td>",$row->editor,"</td>"; echo"</tr>"; } echo"</table>";}catch(Exception$e)//捕捉錯誤信息

{echo$e->getMessage();}?></body></html>進一步?

----修改記錄將show_books.php命名為show_books_update.php在show_books_update.php中,用SQL語句修改《西方經濟學》的價格為60,并把所有圖書信息展示出來進一步??----利用界面增加記錄設計一個修改圖書信息的界面的update_html.php網頁結合show_books_update.php中用SQL語句往book表中修改《西方經濟學》的圖書信息并把所有信息展示出來(數據參看P135示例8-14的結果)update_html.php網頁update_html.php代碼<html><head><metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/><title>修改記錄</title></head><body><formmethod="post"action="show_books_update.php">圖書編號:<inputtype="text"name="bookid"/>【必須填寫】<br/>圖書名稱:<inputtype="text"name="bookname"/><br/>作者:<inputtype="text"name="editor"/><br/>價格:<inputtype="text"name="price"/><br/>出版社:<inputtype="text"name="publish"/><br/>出版日期:<inputtype="text"name="pubdate"/><br/>庫存量:<inputtype="text"name="ckl"/><br/><inputtype="submit"name="ok"value="修改"/><br/></form></body></html>show_books_update.php代碼<html><head><metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/><title>圖書清單</title></head><body><?php$bookid=$_POST["bookid"];$bookname=$_POST["bookname"];$editor=$_POST["editor"];$price=$_POST["price"];$publish=$_POST["publish"];$pubdate=$_POST["pubdate"];$kcl=$_POST["kcl"];

$user="root";$password="";//連接數據庫的用戶名、密碼

$host="localhost";$db_name="bookmanage";//數據庫服務器地址、數據庫名稱

$dsn="mysql:host=$host;dbname=$db_name";//數據源名稱

try{$pdo=newPDO($dsn,$user,$password);//實例化對象

$pdo->query("setnamesutf8"); $update_row_count=$pdo->exec('update`book`set`bookname`="'.$bookname.'",`editor`="'.$editor.'",`price`="'.$price.'",`publish`="'.$publish.'",`pubdate`="'.$pubdate.'",`kcl`="'.$kcl.'"where`bookid`="'.$bookid.'",');

$sql="select*frombook";$rows=$pdo->query($sql); echo"<tableborder=5bordercolor='#999999'> <tr><td>圖書編號</td><td>圖書名稱</td><td>作者</td></tr>"; while($row=$rows->fetch(PDO::FETCH_OBJ)){ echo"<tr>"; echo"<td>",$row->bookid,"</td>"; echo"<td>",$row->bookname,"</td>";echo"<td>",$row->editor,"</td>"; echo"</tr>"; } echo"</table>";}catch(Exception$e)//捕捉錯誤信息

{echo$e->getMessage();}?></body></html>進一步?

----查詢記錄將show_books.php命名為show_books_select.php在show_books_select.php中,用SQL語句c查詢出《西方經濟學》,并把查詢出來的圖書信息展示出來進一步??----利用界面查詢記錄設計一個修改圖書信息的界面的select_html.php網頁結合show_books_select.php中,用SQL語句c查詢出《西方經濟學》,并把查詢出來的圖書信息展示出來select_html.php代碼<html><head><metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/><title>查詢記錄</title></head><body><formmethod="post"action="show_books_select.php">圖書名稱:<inputtype="text"name="bookname"/>【必須填寫】<br/><inputtype="submit"name="ok"value="查詢"/><br/></form></body></html>show_books_select.php代碼<html><head><metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/><title>圖書清單</title></head><body><?php$bookname=$_POST["bookname"];

$user="root";$password="";//連接數據庫的用戶名、密碼

$host="localhost";$db_name="bookmanage";//數據庫服務器地址、數據庫名稱

$dsn="mysql:host=$host;dbname=$db_name";//數據源名稱

try{$pdo=newPDO($dsn,$user,$password);//實例化對象

$pdo->query("setnamesutf8");

$sql="select*frombookwherebooknamelike'%".$bookname."%'";$rows=$pdo->query($sql); echo"<tableborder=5bordercolor='#999999'> <tr><td>圖書編號</td><td>圖書名稱</td><td>作者</td> <td>價格</td><td>出版社</td><td>出版日期</td><td>庫存量</td></tr>"; while($row=$rows->fetch(PDO::FETCH_OBJ)){ echo"<tr>"; echo"<td>",$row->bookid,"</td>"; echo"<td>",$row->bookname,"</td>";echo"<td>",$row->editor,"</td>"; echo"<td>",$row->price,"</td>"; echo"<td>",$row->publish,"</td>"; echo"<td>",$row->pubdate,"</td>"; echo"<td>",$row->kcl,"</td>"; echo"</tr>"; } echo"</table>";}catch(Exception$e)//捕捉錯誤信息

{echo$e->getMessage();}?></body></html>定義一個網站主操作界面main.php

將前面的各個功能整合成網站main.php代碼<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>主操作界面</title><scriptsrc=""></script><style>*{margin:0;padding:0}html,body{height:100%}#nav{float:left;width:15%;height:100%;background-color:antiquewhite}#con{float:right;width:85%;height:100%;background-color:aqua}</style><script>$(document).ready(function(){//頁面加載的時候,內容框默認show_books.php$('#con').load('./show_books.php'); //單擊mainmenu鏈接,加show_books.php$("#mainmenu").click(function(){$('#con').load('./show_books.php');});//單擊insertmenu鏈接,加載insert_html.html$("#insertmenu").click(function(){$('#con').load('./insert_html.php');});//單擊updatemenu鏈接,加載update_html.html$("#updatemenu").click(function(){$('#con').load('./update_html.php');}); //單擊selectmenu鏈接,加載select_html.html$("#selectmenu").click(function(){$('#con').load('./select_html.php');});})</script></head><body><ulid="nav"><li><ahref="#"id="mainmenu">主操作界面</a></li><li><ahref="#"id="insertmenu">增加</a></li><li><ahref="#"id="updatemenu">修改</a></li><li><ahref="#"id="selectmenu">查詢</a></li></ul><divid="con"></div></body></html>思考???前面搭建的網站,普通用戶能操作嗎?這樣有什么危險??-----怎么辦???弄一個登錄驗證頁面------當用戶輸入正確用戶名和密碼,才能訪問main.php登錄驗證相關問題創建user表設計登錄頁面login_html.php設計登錄驗證程序login_check.php創建user表創建表格:CREATETABLE`user`(`name`varchar(10)NOTNULLCOMMENT'用戶名',`password`varchar(10)NOTNULLCOMMENT'密碼')ENGINE=InnoDBDEFAULTCHARSET=utf8;添加數據:INSERTINTO`user`(`name`,`password`)VALUES('linronghai','12345678'),('yinbin','12345678');設計登錄頁面login_html.php<html><head><metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/><title>登錄界面</title></head><body><formmethod="post"action="login_check.php">姓名:<inputtype="text"name="myName"/><br/>密碼:<inputtype="password"name="myPassword"/><br/><inputtype="submit"name="mylogin"value="登錄"/></form></body></html>設計登錄驗證程序???login_check.php<?phpheader("Content-Type:text/html;charset=utf-8");$name=$_POST["myName"];$password=$_POST["myPassword"];//怎么知道姓名和密碼是否對了呢??>怎么知道姓名和密碼是否對了呢???????select*fromuserwherename='yinbin'andpassword='12345678'可否利用上面的語句呢?怎么知道姓名和密碼是否對了呢?能判斷登錄信息的login_check.php<?phpheader("Content-Type:text/html;charset=utf-8");$myName=$_POST["myName"];$myPassword=$_POST["myPassword"];//怎么知道姓名和密碼是否對了呢?$dsn="mysql:host=localhost;dbname=bookmanage";$db_user="root";$db_password="";$pdo=newPDO($dsn,$db_user,$db_password);$pdo->query("setnamesutf8");$sql="select*fromuserwherename='".$myName."'andpassword='".$myPassword."'";$rows=$pdo->query($sql);if($row=$rows->fetch(PDO::FETCH_OBJ)){ echo"姓名和密碼正確";}else{echo"姓名或密碼錯誤";}?>自動跳轉到別的頁面???當姓名和密碼都對了,如何跳轉到main.php當姓名或密碼都錯了,如何跳回到login_html.php網頁自動跳轉(1)跳轉到主操作界面main.phpecho'<metahttp-equiv="refresh"content="4;URL=main.php">';(2)跳轉到登錄界面login_html.phpecho'<metahttp-equiv="refresh"content="4;URL=login_html.php">';此時的login_check.php帶跳轉的login_check.php代碼<?phpheader("Content-Type:text/html;charset=utf-8");$myName=$_POST["myName"];$myPassword=$_POST["myPassword"];//怎么知道姓名和密碼是否對了呢?$dsn="mysql:host=localhost;dbname=bookmanage";$db_user="root";$db_password="";$pdo=newPDO($dsn,$db_user,$db_password);$pdo->query("setnamesutf8");$sql="select*fromuserwherename='".$myName."'andpassword='".$myPassword."'";$rows=$pdo->query($sql);if($row=$rows->fetch(PDO::FETCH_OBJ)){ echo"姓名和密碼正確"; echo'<metahttp-equiv="refresh"content="4;URL=main.php">';}else{echo"姓名或密碼錯誤"; echo'<metahttp-equiv="refresh"content="4;URL=login_html.php">';}?>前面形成了------

功能較完善的網站(1)登錄驗證進入后臺頁面(2)后臺頁面中A.可增加產品B.修改產品C.查找產品D.刪除產品14.2PDO連接數據庫

在PDO中,要建立與數據庫的連接,需要實例化PDO的構造函數。PDO構造函數的語法格式如下:construct(stringdsn,stringusername,stringpassword,arraydriver_options)參數含義dsn規定PDO的數據源名,包括主機名(地址)、端口號和數據庫名稱username可選。規定PDO連接數據庫的用戶名password可選。規定PDO連接數據庫的密碼driver_options可選。規定連接數據庫的其他選項。具體內容參考PDO預定義常量的內容【實例14-1】使用PDO連接MySQL數據庫。

<?phpheader("Content-Type:text/html;charset=gb2312");$db_name="student";//數據庫名稱

$user="root";//連接數據庫的用戶名

$password="";//連接數據庫的密碼

$host="localhost";//數據庫服務器地址

$dsn="mysql:host=$host;dbname=$db_name";//數據源名稱

try{

$pdo=newPDO($dsn,$user,$password);//實例化對象

echo"PDO連接數據庫成功!";

}catch(Exception$e)//捕捉錯誤信息

{echo$e->getMessage();

}?>為了編程方便,可以將PDO連接數據庫的代碼編輯成一個獨立的PHP程序文件(如pdo_connect.php),需要使用PDO連接數據庫的時候,可以通過include()或include_once()語句調用該程序文件。程序文件pdo_conncet.php程序文件代碼如下:<?php$db_name="student";//數據庫名稱

$user="root";//連接數據庫的用戶名

$password="";//連接數據庫的密碼

$host="localhost";//數據庫服務器地址

$dsn="mysql:host=$host;dbname=$db_name";//數據源名稱

try{$pdo=newPDO($dsn,$user,$password);//實例化對象

$pdo->query("setnamesgb2312");}catch(Exception$e)//捕捉錯誤信息

{

echo$e->getMessage();

}?>14.3

在PDO中執行SQL語句PDO連接數據庫成功后,就可以執行SQL語句操作數據表了。在PDO中執行SQL語句主要采用三種方法:exec()方法、query()方法和預處理語句prepare()及execute()。14.3.1exec()方法exec()方法執行后返回受影響記錄的行數,其語法格式如下:intPDO:exec(stringstatement)參數含義statement規定要執行的SQL語句。SQL語句通常指INSERT、DELETE和UPDATE語句【實例14-2】使用exec()方法執行刪除操作。假設數據庫student包含數據表score,數據表的記錄如表14-3所示。使用exec()方法,刪除其中cj字段值小于60的記錄。xhxmbjkccj150212101方波材料2015高等數學92150412312李靜文法2015英語47..............................150313223于文華會計2015社會學67150112224董海川自動化2015哲學58<?phpheader("Content-Type:text/html;charset=gb2312");

include_once("pdo_connect.php");$sql="deletefromscorewherecj<60";//要執行的SQL語句

try{

$rows=$pdo->exec($sql);//執行SQL語句

echo"共刪除記錄:",$rows;

}catch(Exception$e)

{echo$e->getMessage();}?>14.3.2query()方法query()方法執行后返回查詢后的結果集,其語法格式如下:

PDOStatementPDO:query(stringstatement)

參數含義statement規定要執行的SQL語句。SQL語句通常指SELECT語句【實例14-3】使用query()方法執行查詢操作。

<?phpheader("Content-Type:text/html;charset=gb2312");

include_once("pdo_connect.php");

$sql="select*fromscorewherecj>=60";try{

$result=$pdo->query($sql);foreach($resultas$r){

echo$r["xh"],"",$r["xm"],"",$r["bj"],"",$r["kc"],"",$r["cj"],"<br/>";

}}catch(Exception$e){echo$e->getMessage();}?>14.3.3預處理語句prepare()和execute()【深入學習-自學】prepare()方法先做查詢的準備工作,然后調用execute()方法執行查詢,并且還可以通過bindParam()方法來綁定參數提供給execute()方法。prepare()方法和execute()方法的語法格式如下:

PDOStatementPDO:prepare(stringstatement,arraydriver_option)boolPDOStatement::execute(arrayinput_prarameters)參數含義statement規定要執行的操作語句driver_options可選。規定連接數據庫的其他選項,具體內容參考PDO預定義常量內容參數含義input_parameters可選。規定prepare()方法要執行SQL語句的參數表

execute()方法的參數說明【實例14-4】使用prepare()方法和execute()方法添加記錄。

<?phpheader("Content-Type:text/html;charset=gb2312");

include_once("pdo_connect.php");$query="insertintoscoreset

xh=:s_xh,xm=:s_xm,bj=:s_bj,kc=:s_kc,cj=:s_cj";try{$result=$pdo->prepare($query);$result->execute(array(':s_xh'=>'140213023',':s_xm'=>'錢文剛',':s_bj'=>'金融2014',':s_kc'=>'西方經濟學',':s_cj'=>67));echo"記錄成功加入!";}catch(Exception$e){echo$e->getMessage();}?>【實例14-5】使用prepare()方法和execute()方法查詢記錄。<?phpheader("Content-Type:text/html;charset=gb2312");

include_once("pdo_connect.php");$query="select*fromscorewherecj>=:s_cj";try{$result=$pdo->prepare($query);$result->execute(array(':s_cj'=>60));while($r=$result->fetch(PDO::FETCH_ASSOC)){echo$r["xh"],"";echo$r["xm"],"";echo$r["bj"],"";echo$r["kc"],"";echo$r["cj"],"<br/>";}}catch(Exception$e){echo$e->getMessage();}?>14.4

PDO獲取結果集當使用PDO->query()或使用prepare()和execute()查詢記錄時,會得到返回的結果集,常用的獲取結果集的方法有:fetch()、fetchAll()和fetchColumn()。14.4.1fetch()方法fetch()方法獲取結果集中的下一行,其語法格式如下:mixedPDOStatement::fetch(intfetch_style,intcursor_orientation,intcursor_offset)參數含義fetch_style可選。規定結果集的返回方式,具體值如表14-8所示cursor_orientation可選。規定PDOStatement對象的一個浮動游標,可用于獲取指定的一行cursor_offset可選。規定游標的偏移量值含義PDO::FETCH_ASSOC關聯數組形式PDO::FETCH_NUM數字索引數組形式PDO::FETCH_BOTH兩者數組形式都有,為默認值PDO::FETCH_OBJ按照對象的形式PDO::FETCH_BOUND以布爾值的形式返回結果,同時將獲取的列的值賦給bindParam()方法中指定的變量PDO::FETCH_LAZY以關聯數組、數字索引數組對象和對象三種形式返回結果表

fetch_style()可選值show_books.php【實例14-6】使用fetch()方法獲取結果集的數據。

<?phpheader("Content-Type:text/html;charset=gb2312");

include_once("pdo_connect.php");$query="select*fromscore";try{$result=$pdo->prepare($query);$result->execute();while($r=$result->fetch(PDO::FETCH_OBJ))

{

echo$r->xh,"";echo$r->xm,"";echo$r->bj,"";echo$r->kc,"";echo$r->cj,"<br/>";}}catch(Exception$e){echo$e->getMessage();}?>14.4.2fetchAll()方法fetchAll()方法可以獲取結果集的全部行,它的返回值是一個包含結果集中所有數據的二維數組。其語法格式如下:

arrayPDOStatement::fetchAll(intfetch_style,intcolumn_index)

參數含義fetch_style可選。規定結果集的返回方式,可選值見表14-8column_index可選。規定字段的索引值【實例14-7】使用fetchAll()方法獲取結果集的全部數據。<?phpheader("Content-Type:text/html;charset=gb2312");

include_once("pdo_connect.php");$query="select*fromscore";try{$result=$pdo->prepare($query);$result->execute();$r=$result->fetchAll(PDO::FETCH_ASSOC);

for($i=0;$i<count($r);$i++){

echo$r[$i]["xh"],"";echo$r[$i]["xm"],"";echo$r[$i]["bj"],"";echo$r[$i]["kc"],"";echo$r[$i]["cj"],"<br/>";}}catch(Exception$e){echo$e->getMessage();}?>14.4.3fetchColumn()方法fetchColumn()方法獲取結果集中下一行的指定列的值,其語法格式如下:

stringPDOStatement::fetchColumn(intcolumn_number)參數含義column_num可選。規定字段的索引值,從0開始。若忽略,則從第一列開始取值【實例14-8】使用fetchColumn()獲取結果集中下一行的一列數據。

<?phpheader("Content-Type:text/html;charset=gb2312");

include_once("pdo_connect.php");$query="select*fromscore";$result=$pdo->prepare($query);$result->execute();echo$result->fetchColumn(0);//獲取第一行第一列的值

?>14.5PDO錯誤處理(體驗)

show_books_err.php14.5PDO錯誤處理(體驗)

show_books_err.php前句話作用:定義了錯誤發生時的處理方式有它的區別當出現錯誤時-----可以捕獲這個錯誤,并在網頁中顯示錯誤原因大大方便我們調試程序!show_books_err.php

出錯提示演示show_books_err.php

出錯提示演示14.5PDO錯誤處理(體驗)

show_books_err.php<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"""><htmlxmlns=""><head><metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/><title>圖書清單</title></head><body><?php$user="root";$password="";//連接數據庫的用戶名、密碼

$host="localhost";$db_name="bookmanage";//數據庫服務器地址、數據庫名稱

$dsn="mysql:host=$host;dbname=$db_name";//數據源名稱

try{$pdo=newPDO($dsn,$user,$password);//實例化對象

$pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); $pdo->query("setnamesutf8"); $sql="select*frombook";$rows=$pdo->query($sql); echo"<tableborder=5bordercolor='#999999'> <tr><td>圖書編號</td><td>圖書名稱</td><td>作者</td></tr>"; while($row=$rows->fetch(PDO::FETCH_OBJ)){ echo"<tr>"; echo"<td>",$row->bookid,"</td>"; echo"<td>",$row->bookname,"</td>";echo"<td>",$row->editor,"</td>"; echo"</tr>"; } echo"</table>";}catch(Exception$e)//捕捉錯誤信息

{echo$e->getMessage();}?></body></html>14.7PDO事務處理(略)在PDO中也可以進行事務的處理,包括:開啟事務、提交事務以及回滾事務。1.開啟事務開啟事務是通過beginTransaction()方法來實現的。該方法將關閉自動提交(mit)模式,直到事務提交或者事務回滾以后才恢復。2.事務提交事務提交是通過commit()方法來完成的。該方法若提交成功,則返回TRUE,否則返回FALSE。3.事務回滾事務回滾是通過rollback()方法來完成的。【實例14-14】事務的開啟、提交以及回滾。

<?phpheader("Content-Type:text/html;charset=gb2312");include_once("pdo_connect.php");//通過PDO連接數據庫

try

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

$sql="updatescoresetbj='通信2015'wherexh='150212101'";

$result=$pdo->prepare($sql);

$result->execute();$pdo->commit();//提交事務

}catch(PDOException$e)

{

echo"錯誤:",$e->getMessage();$pdo->rollback();//回滾事務

}?>14.8綜合實訓案例本節主要介紹利用PDO設計用戶登錄界面的方法和步驟。1.分析假定有數據庫bookmanage,其中包含數據表user,表結構如表所示字段字段類型含義namevarchar用戶名passwordva

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論