欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php實(shí)現(xiàn)PDO中捕獲SQL語句錯誤的方法

 更新時間:2017年02月16日 10:32:39   作者:水晶依戀  
這篇文章主要介紹了php實(shí)現(xiàn)PDO中捕獲SQL語句錯誤的方法,結(jié)合實(shí)例形式分析了PDO中常見的錯誤、警告及異常模式相關(guān)屬性設(shè)置與使用技巧,需要的朋友可以參考下

本文實(shí)例講述了php實(shí)現(xiàn)PDO中捕獲SQL語句錯誤的方法。分享給大家供大家參考,具體如下:

使用默認(rèn)模式-----PDO::ERRMODE_SILENT

在默認(rèn)模式中設(shè)置PDOStatement對象的errorCode屬性,但不進(jìn)行其他任何操作。

例如:

通過prepare()和execute()方法向數(shù)據(jù)庫中添加數(shù)據(jù),設(shè)置PDOStatement對象的erroCode屬性,手動檢測代碼中的錯誤,操作步驟如下。

$dbms='mysql';//數(shù)據(jù)庫類型
$dbName='admin';//使用的數(shù)據(jù)庫
$user='root';//數(shù)據(jù)庫連接用戶名
$pwd='password';//數(shù)據(jù)庫連接密碼
$host='localhost';//數(shù)據(jù)庫主機(jī)名
$dsn="$dbms:host=$host;port=3306;dbname=$dbName";
$pdo=new PDO($dsn,$user,$pwd);//初始化一個PDO對象,就是創(chuàng)建了數(shù)據(jù)庫連接對象$pdo
$query="insert into user (username,password) values('admin')";//需要執(zhí)行的sql語句
$res=$pdo->prepare($query);
$res->execute();
$code=$res->errorCode();
echo $code.'<br>';
if($code==00000){//如果沒有任何錯誤, errorCode() 返回的是: 00000 ,否則就會返回一些錯誤代碼
echo "數(shù)據(jù)添加成功";
}else{
echo "數(shù)據(jù)庫錯誤:<br>";
echo 'SQL Query:'.$query;
echo '<pre>';
var_dump($res->errorInfo());
echo '<pre>';
}

運(yùn)行結(jié)果如下

21S01

數(shù)據(jù)庫錯誤:

SQL Query:insert into user (username,password) values('admin')
array(3) {
 [0]=>
 string(5) "21S01"
 [1]=>
 int(1136)
 [2]=>
 string(47) "Column count doesn't match value count at row 1"
}

使用警告模式-----PDO::ERRMODE_WARNING

警告模式會產(chǎn)生一個PHP警告,并設(shè)置errorCode屬性。如果設(shè)置的是警告模式,那么除非明確的檢查錯誤代碼,否則程序?qū)⒗^續(xù)按照其方式運(yùn)行。

例如:

設(shè)置警告模式,通過prepare()和execute()方法讀取數(shù)據(jù)庫中數(shù)據(jù),并且通過while語句和fetch()方法完成數(shù)據(jù)的循環(huán)輸出,體會在設(shè)置成警告模式后執(zhí)行錯誤的SQL的語句。

$dbms='mysql';//數(shù)據(jù)庫類型
$dbName='admin';//使用的數(shù)據(jù)庫
$user='root';//數(shù)據(jù)庫連接用戶名
$pwd='password';//數(shù)據(jù)庫連接密碼
$host='localhost';//數(shù)據(jù)庫主機(jī)名
$dsn="$dbms:host=$host;port=3306;dbname=$dbName";
try {
$pdo = new PDO($dsn, $user, $pwd);//初始化一個PDO對象,就是創(chuàng)建了數(shù)據(jù)庫連接對象$pdo
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);//設(shè)置為警告模式
$query = "select * from userrr";//需要執(zhí)行的sql語句
$res = $pdo->prepare($query);//準(zhǔn)備查詢語句
$res->execute();
while ($result = $res->fetch(PDO::FETCH_ASSOC)) {//while循環(huán)輸出查詢結(jié)果集并設(shè)置結(jié)果集以關(guān)聯(lián)數(shù)組的形式返回。
echo $result['id'] . " " . $result['username'] . " " . $result['password'];
  }
}catch(PDOException $e){
die("ERROR!:".$e->getMessage().'<br>');
}
echo "繼續(xù)繼續(xù)繼續(xù)繼續(xù)繼續(xù)繼續(xù)繼續(xù)";

運(yùn)行結(jié)果如下:

Warning: PDOStatement::execute() [pdostatement.execute]: SQLSTATE[42S02]: Base table or view not found: 1146 Table 'admin.userrr' doesn't exist in D:\wampserver\www\test\test\index1.php on line 14

 
繼續(xù)繼續(xù)繼續(xù)繼續(xù)繼續(xù)繼續(xù)繼續(xù)

可以看出在設(shè)置警告模式后,如果SQL語句出現(xiàn)錯誤將給出一個提示信息,但是程序仍能夠繼續(xù)執(zhí)行下去。

使用異常模式----PDO::ERRMODE_EXCEPTION

異常模式將會創(chuàng)建一個PDOException,并設(shè)置errorCode屬性,它可以將執(zhí)行代碼封裝到一個try{}catch{}語句塊中。未捕獲的異常將會導(dǎo)致腳本中斷,并顯示堆棧跟蹤讓用戶了解是哪里出現(xiàn)了問題。

例如:

刪除一個錯誤的數(shù)據(jù)表中的信息

$dbms='mysql';//數(shù)據(jù)庫類型
$dbName='admin';//使用的數(shù)據(jù)庫
$user='root';//數(shù)據(jù)庫連接用戶名
$pwd='password';//數(shù)據(jù)庫連接密碼
$host='localhost';//數(shù)據(jù)庫主機(jī)名
$dsn="$dbms:host=$host;port=3306;dbname=$dbName";
try {
$pdo = new PDO($dsn, $user, $pwd);//初始化一個PDO對象,就是創(chuàng)建了數(shù)據(jù)庫連接對象$pdo
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);//設(shè)置異常模式
$query = "delete from userrr where id=1";//需要執(zhí)行的sql語句
$res = $pdo->prepare($query);//準(zhǔn)備刪除語句
$res->execute();
}catch(PDOException $e){
echo 'PDO Exception Caught: ';
echo "Error with the database:<br>";
echo 'SQL Query:'.$query;
echo '<pre>';
echo "ERROR:".$e->getMessage().'<br>';
echo "Code:".$e->getCode().'<br>';
echo "File:".$e->getFile().'<br>';
echo "Line:".$e->getLine().'<br>';
echo "Trace:".$e->getTraceAsString().'<br>';
echo '</pre>';
}

運(yùn)行結(jié)果:

PDO Exception Caught: Error with the database:
SQL Query:delete from userrr where id=1
ERROR:SQLSTATE[42S02]: Base table or view not found: 1146 Table 'admin.userrr' doesn't exist
Code:42S02
File:D:\wampserver\www\test\test\index1.php
Line:14
Trace:#0 D:\wampserver\www\test\test\index1.php(14): PDOStatement->execute()
#1 {main}

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP基于pdo操作數(shù)據(jù)庫技巧總結(jié)》、《php+Oracle數(shù)據(jù)庫程序設(shè)計(jì)技巧總結(jié)》、《PHP+MongoDB數(shù)據(jù)庫操作技巧大全》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總

希望本文所述對大家PHP程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • centos 5.6 升級php到5.3的方法

    centos 5.6 升級php到5.3的方法

    centos 5.6的庫,更新比比5.5及時多了,居然已經(jīng)有 php 5.3.3 了
    2011-05-05
  • php加速器eAccelerator的配置參數(shù)、API詳解

    php加速器eAccelerator的配置參數(shù)、API詳解

    eAccelerator是一個開源PHP加速器,優(yōu)化程序,編碼器和動態(tài)內(nèi)容緩存。它通過在編譯狀態(tài)下對它們進(jìn)行緩存以提高PHP腳本的性能,所以那些 系統(tǒng)開銷在編譯時幾乎可以被消除
    2014-05-05
  • PHP實(shí)現(xiàn)的字符串匹配算法示例【sunday算法】

    PHP實(shí)現(xiàn)的字符串匹配算法示例【sunday算法】

    這篇文章主要介紹了PHP實(shí)現(xiàn)的字符串匹配算法,簡單描述了sunday算法的概念與原理,并結(jié)合實(shí)例形式分析了php基于sunday算法實(shí)現(xiàn)字符串匹配操作相關(guān)技巧,需要的朋友可以參考下
    2017-12-12
  • PHP 程序員應(yīng)該使用的10個組件

    PHP 程序員應(yīng)該使用的10個組件

    作為一個PHP程序員,你應(yīng)該知道PHP有著最大的代碼庫。所以無論你想在程序中添加什么模塊,肯定能找到開源解決方案。
    2009-10-10
  • PHP中文件鎖的使用詳解

    PHP中文件鎖的使用詳解

    PHP文件鎖是一種用于控制對文件的并發(fā)訪問的機(jī)制,它可以確保同一時間內(nèi)只有一個進(jìn)程或線程可以對文件進(jìn)行讀取或?qū)懭氩僮?下面我們就來了解一下文件鎖的具體使用吧
    2023-12-12
  • php實(shí)現(xiàn)XSS安全過濾的方法

    php實(shí)現(xiàn)XSS安全過濾的方法

    這篇文章主要介紹了php實(shí)現(xiàn)XSS安全過濾的方法,實(shí)例分析了php針對XSS進(jìn)行安全過濾的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-07-07
  • PHP 實(shí)現(xiàn)超簡單的SESSION與COOKIE登錄驗(yàn)證功能示例

    PHP 實(shí)現(xiàn)超簡單的SESSION與COOKIE登錄驗(yàn)證功能示例

    這篇文章主要介紹了PHP 實(shí)現(xiàn)超簡單的SESSION與COOKIE登錄驗(yàn)證功能,結(jié)合實(shí)例形式詳細(xì)分析了PHP使用cookie與session實(shí)現(xiàn)登錄驗(yàn)證的相關(guān)操作步驟與注意事項(xiàng),需要的朋友可以參考下
    2019-12-12
  • 使用PHPWord生成word文檔的方法詳解

    使用PHPWord生成word文檔的方法詳解

    這篇文章主要介紹了使用PHPWord生成word文檔的方法,結(jié)合實(shí)例形式詳細(xì)分析了PHPWord生成word文檔的具體操作步驟與相關(guān)使用技巧,需要的朋友可以參考下
    2019-06-06
  • thinkphp5.1 框架鉤子和行為用法實(shí)例分析

    thinkphp5.1 框架鉤子和行為用法實(shí)例分析

    這篇文章主要介紹了thinkphp5.1 框架鉤子和行為用法,結(jié)合實(shí)例形式分析了thinkphp5.1 框架鉤子和行為基本功能、定義、用法及操作注意事項(xiàng),需要的朋友可以參考下
    2020-05-05
  • 安裝ImageMagick出現(xiàn)error while loading shared libraries的解決方法

    安裝ImageMagick出現(xiàn)error while loading shared libraries的解決方法

    這篇文章主要介紹了安裝ImageMagick出現(xiàn)error while loading shared libraries的解決方法,是ImageMagick安裝與運(yùn)行中經(jīng)常出現(xiàn)的問題,需要的朋友可以參考下
    2014-09-09

最新評論