微擎pdo_fetchall中使用in 查询

问题

有时候我们需要使用MySQL中的in()查询,在微擎中,因为有pdo_系列方法,一般来说,想当然的会像下面这种方式使用:

$ids_string = '1,2,3'; pdo_fetchall("select * from ".tablename('demo_table')." where uniacid=:uniacid and id in (:id)", array(':uniacid'=>$_W['uniacid'], ':id'=>$ids_string));

但是当你运行后,会发现,查询是没有结果的,无论是使用pdo_debug()方法查看过程,都是没有问题的,甚至把打印出来的SQL语句放到phpmyadmin或者MySQL终端下运行,都是可以正常执行的。 方法

我想这里应该是使用PDO预处理语句时出现问题了,具体的代码没有查看,这里只是记录下遇到这个问题的解决方法,还是和上面的代码功能一样,只需改动绑定方式即可。如下:

$ids_string = '1,2,3'; pdo_fetchall("select * from ".tablename('demo_table')." where uniacid=:uniacid and id in ($ids_string)", array(':uniacid'=>$_W['uniacid']));

现在运行就可以了,就是将in的内容直接赋值,而不是预加载绑定。

注意:如果你的pdo_fetchall()方法里用的不是双引号,在直接输入变量时请使用”.$ids_string.”方式。

转载于:https://my.oschina.net/u/3424381/blog/3041877

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值