请问关于PDO的参数(有长度限制,或者Bug)用法
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了请问关于PDO的参数(有长度限制,或者Bug)用法,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1184字,纯文字阅读大概需要2分钟。
内容图文
![请问关于PDO的参数(有长度限制,或者Bug)用法](/upload/InfoBanner/zyjiaocheng/231/9a6b87d29dc24c1f9edf2f77e029b52b.jpg)
请教关于PDO的参数(有长度限制,或者Bug)用法:
有如下句php代码:
$tids='588316104237364, 573473840208171, 585814107854381';
$sql = 'SELECT trade_id,tid,trade_md5,receiver_md5,order_md5,status,llc_no,modified_time FROM ep_trade WHERE tid in ( '.$tids.' ) and biz_id=? limit 10000';
$param[0]=123;
$stmt->execute($param);
可以正确执行,并返回数据3行
但是换一个写法:
$sql = 'SELECT trade_id,tid,trade_md5,receiver_md5,order_md5,status,llc_no,modified_time FROM ep_trade WHERE tid in ( ? ) and biz_id=? limit 10000';
即将变量tid放到参数中:
$param[0]=$tids;
$param[1]=123;
$stmt->execute($param);
总是仅返回第一行?是为何呢。
执行环境:php5.1 centos 5.7, mysql 5.1
分数很多,付点$也行的,求解,谢谢。
------解决方案--------------------
不是PDO的bug,是PDO的规则如此。
使用PDO需要注意几种情况
1.不能让占位符 ? 代替一组值,如:
select * from table where id in(?);
就是你遇到的情况,当是一组值时,只会取第一个值。
2.不能让占位符代替数据表名或列名,如:
select * from table order by ?;
3.不能让占位符 ? 代替任何其他SQL语法,如:
select extract(? from addtime) as dt from table;
------解决方案--------------------
正解!
所以 tid in ( ? )
可写作 find_in_set( tid, ? )
内容总结
以上是互联网集市为您收集整理的请问关于PDO的参数(有长度限制,或者Bug)用法全部内容,希望文章能够帮你解决请问关于PDO的参数(有长度限制,或者Bug)用法所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。