php在5.1.和5.2.之间pdo数据库操作中的不同

上传人:xiao****1972 文档编号:84085890 上传时间:2019-03-02 格式:DOCX 页数:4 大小:33.06KB
返回 下载 相关 举报
php在5.1.和5.2.之间pdo数据库操作中的不同_第1页
第1页 / 共4页
php在5.1.和5.2.之间pdo数据库操作中的不同_第2页
第2页 / 共4页
php在5.1.和5.2.之间pdo数据库操作中的不同_第3页
第3页 / 共4页
php在5.1.和5.2.之间pdo数据库操作中的不同_第4页
第4页 / 共4页
亲,该文档总共4页,全部预览完了,如果喜欢就下载吧!
资源描述

《php在5.1.和5.2.之间pdo数据库操作中的不同》由会员分享,可在线阅读,更多相关《php在5.1.和5.2.之间pdo数据库操作中的不同(4页珍藏版)》请在金锄头文库上搜索。

1、 介绍 今天发现php5.1.*和php5.2.*在数据库预编译代码执行的时候出现差异。 预编译优点 1.使用占位符,避免逐字输入数据到SQL中。自动处理引号和反斜线等字符的转义增加安全性。 2.预先“准备”一条语句,然后在每次执行时绑定不同值达到重用的目的。常用于以后被多次执行的语句。 3.可读性强。 代码 数据库连接代码都一样. $protol = mysql:host=localhost;dbname=test; $username = monty; $passwd = 0818; $dbh = new PDO($protol, $username, $passwd); 以下是一些测试。

2、注意里面的SQL和for或者foreach语句! 测试1(用key值进行绑定) $stmt = $dbh-prepare(select * from t1 where name=:name); $params = array(); $paramsname = rentao; foreach($params as $k=$v) $stmt-bindParam($k, $v); $stmt-execute(); $item = array(); while($row = $stmt-fetch(PDO:FETCH_ASSOC) var_dump($row); $stmt = null; $dbh

3、= null; 结论: PHP 5.1.* PHP 5.2.* 执行正常 执行正常 $paramsname = rentao 和$params:name=rentao这两个都能执行,说明不受“:”限制。 测试2(数字下标去绑定,但是绑定的起始参数是1)“:key“在php5.2.*上不能用数字下标绑定 $stmt = $dbh-prepare(select * from t1 where name=:name limit 2); $params = array(); $params = rentao;/ 这里加不加“:“都能成功执行 for($i=0,$iLen = count($params

4、); $i bindParam($k, $params$i); echo “HERE1n“; $stmt-execute(); echo “HERE2n“; $item = array(); 介绍 while($row = $stmt-fetch(PDO:FETCH_ASSOC) var_dump($row); $stmt = null; $dbh = null; 结论: php 5.1.* PHP 5.2.* 执行正常 出现错误:“PHP Warning: PDOStatement:execute(): SQLSTATEHY093: Invalid parameter number: par

5、ameter was not defined” 如果把“:name“改成“?“,那么两个版本都可以顺利进行。 不能同时使用两种符号。如 select * from t2 where name=? limit :page 测试3(limit绑定:page) $stmt = $dbh-prepare(select * from t2 where name=:name limit :page); $params = array(); $paramsname = rentao;/ 这里加不加“:“都能成功执行 $paramspage = 2; foreach($params as $k=$v) $st

6、mt-bindParam($k, $v); $stmt-execute(); echo “HERE1n“; $item = array(); while($row = $stmt-fetch(PDO:FETCH_ASSOC) var_dump($row); echo “HERE2n“; $stmt = null; $dbh = null; 结论: PHP 5.1.* PHP 5.2.* 执行到$stmt-execute()时,进程一直处于等待状态中 执行正常:打印不出结果 测试4(在limit下进行预编译操作:page)使用“?”机制运行 $stmt = $dbh-prepare(select

7、 * from t2 where name=? limit ?); $params = array(); $params = rentao; $params = 2; for($i=0,$iLen = count($params); $i bindParam($k, $params$i); $stmt-execute(); $item = array(); while($row = $stmt-fetch(PDO:FETCH_ASSOC) var_dump($row); $stmt = null; $dbh = null; PHP 5.1.* PHP 5.2.* 执行正常 执行正常:打印不出结

8、果 测试5-order by) PHP 5.1.* PHP 5.2.* 打印出结果,但未按order by进行排序 执行正常:打印不出结果 写问题 数据库写操作,我们用的都是数字下标绑定的办法(function execute()。所以,凡是做写入操作的必须用“?“的形式,否则不支持绑定。 总结 PHP在使用PDO做数据库预编译操作的时候,尽量避免使用limit, order by, group by 做预编译处理。绑定变量我们尽量使用统一标准,要不然都使用“?”,要不然使用“:key”。 有用的命令,我在php5.1.*进行测试,测试完了,我通过scp把文件传输到php5.2.*服务器上 scp -P9888 index.php rentao192.168.10.4:/home/rentao

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号