【发布时间】:2017-01-24 16:28:15
【问题描述】:
我想知道当execute()返回false时,PDO是否会抛出异常。
<?php
$db = new PDO('mysql:host=localhost;dbname='.$dbname, $user, $pass,array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8"));
$db->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
try{
$db->beginTransaction();
$query = $db->prepare('INSERT INTO threads (title,perma) VALUES ("hey", "hey")');
if(!$query->execute())
{
echo ":(";
}
}catch(Exception $e){
echo ":)";
$db->rollBack();
}
?>
是否可以看到':('?我应该手动抛出异常吗?
【问题讨论】:
-
你为什么不简单地尝试一下?做一个原始的测试用例(一个 10 行的脚本),你就有答案了……