sql語句問題是沒有必要攔截的,如果把sql語句輸出來讓用戶看到是件危險(xiǎn)的事情,至于數(shù)據(jù)庫或其他異常,可以參考set_error_handler(array('錯(cuò)誤處理類', '方法')),然后建立一個(gè)自己的錯(cuò)誤處理類和方法,自己對(duì)錯(cuò)我進(jìn)行處理,上面的函數(shù)也能讓php觸發(fā)錯(cuò)誤時(shí)自動(dòng)調(diào)用
目前創(chuàng)新互聯(lián)已為成百上千的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)站空間、網(wǎng)站運(yùn)營、企業(yè)網(wǎng)站設(shè)計(jì)、宏偉網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
記得采納啊
沒有錯(cuò)???
上一個(gè)可以顯示,下一個(gè)你可能重寫了Exception,也應(yīng)該沒錯(cuò)。
難道你的PHP不支持異常?
Uncaught exception 'Exception' ,有這個(gè),沒道理???
難道php里面就非得用throw才能捕獲異常嗎
==============
是的.異常捕獲不是用來處理語法錯(cuò)誤,不是用來處理fatal
error,更不是用來處理die()的。它只能用來處理throw出來的異常。
可以使用 mysql_errno() 來判斷上一條sql語句是否執(zhí)行成功. 返回非0 都表示錯(cuò)誤.
(若想獲取錯(cuò)誤的文本描述信息 , 可以使用 mysql_error() )
例子:
$資源句柄 = mysql_connect(....);
@mysql_query('abcdee' , $資源句柄);
var_dump(mysql_errno($資源句柄));
var_dump(mysql_error($資源句柄));
================================
實(shí)現(xiàn)判斷語句是否正確. 那就得在拼接sql的時(shí)候下功夫.
如果把字段值的驗(yàn)證與過濾做到位了.
那拼接出來的sql 不會(huì)有問題的.
現(xiàn)在使用PDO鏈接數(shù)據(jù)庫的較多
連接是通過創(chuàng)建 PDO 基類的實(shí)例而建立的。不管使用哪種驅(qū)動(dòng)程序,都是用 PDO 類名。構(gòu)造函數(shù)接收用于指定數(shù)據(jù)庫源(所謂的 DSN)以及可能還包括用戶名和密碼(如果有的話)的參數(shù)。
連接到 MySQL
?php
$dbh?=?new?PDO('mysql:host=localhost;dbname=test',?$user,?$pass);
?
如果有任何連接錯(cuò)誤,將拋出一個(gè) PDOException 異常對(duì)象。如果想處理錯(cuò)誤狀態(tài),可以捕獲異常,或者選擇留給通過 set_exception_handler() 設(shè)置的應(yīng)用程序全局異常處理程序。
處理連接錯(cuò)誤
?php
try?{
$dbh?=?new?PDO('mysql:host=localhost;dbname=test',?$user,?$pass);
foreach($dbh-query('SELECT?*?from?FOO')?as?$row)?{
print_r($row);
}
$dbh?=?null;
}?catch?(PDOException?$e)?{
print?"Error!:?"?.?$e-getMessage()?.?"br/";
die();
}
?
如果應(yīng)用程序不在 PDO 構(gòu)造函數(shù)中捕獲異常,zend 引擎采取的默認(rèn)動(dòng)作是結(jié)束腳本并顯示一個(gè)回溯跟蹤,此回溯跟蹤可能泄漏完整的數(shù)據(jù)庫連接細(xì)節(jié),包括用戶名和密碼。因此有責(zé)任去顯式(通過 catch 語句)或隱式(通過 set_exception_handler() )地捕獲異常。
連接數(shù)據(jù)成功后,返回一個(gè) PDO 類的實(shí)例給腳本,此連接在 PDO 對(duì)象的生存周期中保持活動(dòng)。要想關(guān)閉連接,需要銷毀對(duì)象以確保所有剩余到它的引用都被刪除,可以賦一個(gè) NULL 值給對(duì)象變量。如果不明確地這么做,PHP 在腳本結(jié)束時(shí)會(huì)自動(dòng)關(guān)閉連接。
關(guān)閉一個(gè)連接
?php
$dbh?=?new?PDO('mysql:host=localhost;dbname=test',?$user,?$pass);
//?在此使用連接
//?現(xiàn)在運(yùn)行完成,在此關(guān)閉連接
$dbh?=?null;
?
很多 web 應(yīng)用程序通過使用到數(shù)據(jù)庫服務(wù)的持久連接獲得好處。持久連接在腳本結(jié)束后不會(huì)被關(guān)閉,且被緩存,當(dāng)另一個(gè)使用相同憑證的腳本連接請(qǐng)求時(shí)被重用。持久連接緩存可以避免每次腳本需要與數(shù)據(jù)庫回話時(shí)建立一個(gè)新連接的開銷,從而讓 web 應(yīng)用程序更快。