CakePHP怎么写MySQL的IN条件

我的代码是这么写的

$ids = '1,2,3,4';
$conditions[]=array('id IN (?)'=> $ids);

拼出来的SQL是

SELECT ...ooxx... WHERE id IN ('1,2,3,4');

这条SQL其实是错的,应该是

SELECT ...ooxx... WHERE id IN (1,2,3,4);

我应该在代码里怎么写呢?

阅读 6.7k
2 个回答
$conditions[] = array(
                    'id' => array(1, 2, 3, 4 )
                );

可以通过在对应的字段名后面设置一个包含有值的数组来实现与SQL逻辑运算符IN()同等的效果。

久不用了 ... 在我记忆中直接传递数组即可 ...

示例如下 ...

$this->foo->find( 'all', array(
    'conditions' => array( 'foo.bar' => array( 1, 2, 3, 4 ) )
) );
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题