• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

php 搞代码 3年前 (2022-01-23) 26次浏览 已收录 0个评论
文章目录[隐藏]

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

<code><?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();?></code>

mysql日志:

<code>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    </code>

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

php版本 5.2.17


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

本¥文来源gaodai$ma#com搞$代*码*网(搞代gaodaima码

回复内容:

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

<code><?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();?></code>

mysql日志:

<code>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    </code>

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

php版本 5.2.17


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

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


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:PDO操作,设置了ATTR_EMULATE_PREPARES属性为false后发现还是在本地模拟prepare

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址