【问题标题】:Will PDO throw an exception if execute() returns false?如果 execute() 返回 false,PDO 会抛出异常吗?
【发布时间】: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 行的脚本),你就有答案了……

标签: php pdo


【解决方案1】:

如果 execute() 返回 false,PDO 会抛出异常吗?

是的。

您始终可以创建一个测试用例并自己查看

$pdo = new PDO("mysql:host=localhost;dbname=$dbname;charset=utf8", $user, $pass);
$pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

$pdo->query("CREATE temporary TABLE executest (id int auto_increment primary key)");

$stmt = $pdo->prepare("INSERT INTO executest VALUES (?)");
$stmt->execute([1]);
$stmt->execute([1]);

【讨论】:

    猜你喜欢
    • 2012-07-21
    • 2014-03-03
    • 1970-01-01
    • 2019-05-15
    • 1970-01-01
    • 1970-01-01
    • 2017-09-17
    • 2016-10-23
    • 1970-01-01
    相关资源
    最近更新 更多