首页 > 其他分享 >微擎pdo_fetchall中使用in 查询

微擎pdo_fetchall中使用in 查询

时间:2022-11-17 14:58:10浏览次数:68  
标签:fetchall string 微擎 uniacid ids pdo id

有时候我们需要使用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的内容直接赋值,而不是预加载绑定。

标签:fetchall,string,微擎,uniacid,ids,pdo,id
From: https://www.cnblogs.com/zwvs/p/16899459.html

相关文章