2

无论 PDO 是否在FALSEPDO::ATTR_EMULATE_PREPARES的设置为TRUE的情况下执行,如何判断 PDO 是否实际模拟语句或它们是否由本机驱动程序处理?

4

1 回答 1

0

好吧,它似乎不能用作 PDO 连接处理程序属性,因为可以在运行时更改此设置。
但是可以为语句处理程序获取它。
因此,如果您想在开始任何实际语句之前了解仿真状态,则必须使用假查询。作为一个额外的证明,可以使用我关于揭示仿真的小技巧:

try {
    $pdo->setAttribute( PDO::ATTR_EMULATE_PREPARES, FALSE);
    $sth  = $pdo->prepare("SELECT 1");
    $emul = $sth->getAttribute(PDO::ATTR_EMULATE_PREPARES);
    var_dump($emul);
    $sth = $pdo->prepare("SELECT 1 LIMIT ?,?");
    $sth->execute(array(1,2));    

    $pdo->setAttribute( PDO::ATTR_EMULATE_PREPARES, TRUE);
    $sth  = $pdo->prepare("SELECT 1");
    $emul = $sth->getAttribute(PDO::ATTR_EMULATE_PREPARES);
    var_dump($emul);
    $sth = $pdo->prepare("SELECT 1 LIMIT ?,?");
    $sth->execute(array(1,2));    
} catch (PDOException $e) {
    echo $e->getMessage();
}

输出

bool(false)
bool(true)
SQLSTATE[42000]: Syntax error or access violation:
1064 You have an error in your SQL syntax;
check the manual that corresponds to your MySQL server version 
for the right syntax to use near ''1','2'' at line 1

意味着在第二种情况下 PDO 只是模拟,因此将值格式化为导致解析错误的字符串。

尽管我认为此类信息没有多大用处。为什么不将其设置为您想要的任何条件?

于 2013-01-23T05:27:18.817 回答