搜索
php - PDO操作,设置了ATTR_EMULATE_PREPARES属性为false后发现还是在本地模拟prepare
高洛峰
高洛峰 2017-04-10 18:08:44
[PHP讨论组]

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)。如果驱动不能成功预处理当前查询,它将总是回到模拟预处理语句上
我这里是不是因为驱动没有成功预处理当前查询到导致的问题?

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(1)
怪我咯

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

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号