>백엔드 개발 >PHP 튜토리얼 >PDO操作,设置了ATTR_EMULATE_PREPARES属性为false后发现还是在本地模拟prepare

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

WBOY
WBOY원래의
2016-07-06 13:52:431751검색

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

回复内容:

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 环境就可以顺利的进行预处理了

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.