微擎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的内容直接赋值,而不是预加载绑定。