Maison >développement back-end >tutoriel php >PDO操作,设置了ATTR_EMULATE_PREPARES属性为false后发现还是在本地模拟prepare
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 环境就可以顺利的进行预处理了