PDO操作,设置了ATTR_EMULATE_PREPARES属性为false后发现还是在本地模拟prepare

PDO操作,设置了ATTR_EMULATE_PREPARES属性为false后发现还是在本地模拟prepare

<?php
//连接数据库部分
try{
    $dbh = new PDO('mysql:dbname=test;host=localhost','root','root');
    //设置捕获异常
    $dbh -> setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
    //设置禁止本地模拟prepare
    $dbh -> setAttribute(PDO::ATTR_EMULATE_PREPARES,false);
    $dbh -> exec('set names gbk');
}catch(PDOException $e){
    echo '数据库连接失败:'.$e->getMessage();
    exit;
}
$query = "SELECT * FROM news WHERE tid=?";
$stmt = $dbh -> prepare($query);
$tid = $_GET['id'];
//将参数添加到SQL查询中
$stmt -> bindParam(1,$tid);
$stmt -> execute();
?>

mysql日志:

160614 13:14:12       27 Connect    root@localhost on test
           27 Query    set names gbk
           27 Query    SELECT * FROM news WHERE tid='1'
           27 Quit    

发现并未像描述那样:“设置这个属性为false,就不会在本地进行模拟prepare”

php版本 5.2.17


补充内容:
PDO::ATTR_EMULATE_PREPARES 启用或禁用预处理语句的模拟。 有些驱动不支持或有限度地支持本地预处理。使用此设置强制PDO总是模拟预处理语句(如果为 TRUE ),或试着使用本地预处理语句(如果为 FALSE)。如果驱动不能成功预处理当前查询,它将总是回到模拟预处理语句上
我这里是不是因为驱动没有成功预处理当前查询到导致的问题?

阅读 12k
2 个回答

找到问题的所在了,我用的是在win下的环境,当我使用linux下的php5.2.x 环境就可以顺利的进行预处理了

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏