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)。如果驱动不能成功预处理当前查询,它将总是回到模拟预处理语句上。
我这里是不是因为驱动没有成功预处理当前查询到导致的问题?
找到问题的所在了,我用的是在win下的环境,当我使用linux下的php5.2.x 环境就可以顺利的进行预处理了