dongsigan2636 2014-05-20 23:13
浏览 33
已采纳

CakePHP IN数组条件不能使用一个键

I'm trying to find with the condition that the field type has one of a group of selected values. The problem I'm facing is that when select only one item, like this:

$this->Ads->find('all', array(
    'conditions' => array(
       'type IN' => array('other');
    )
);

CakePHP gives an SQL error:

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '= ('other')' at line 1

Query looks like: type IN = ('other') which is wrong.

Is this a CakePHP bug or am I doing something wrong?

I am using CakePHP version: 2.4.2

  • 写回答

1条回答 默认 最新

  • dongren9966 2014-05-20 23:25
    关注

    You don't need the IN operator, Cake works out the variable type (array/string) and adds it automatically when needed:

    // type = 'other'
    'conditions' => array(
        'type' => 'other'
    )
    
    // type = 'other' syntax 2
    'conditions' => array(
        'type' => array('other'),           
    )
    
    // type IN ('other', 'other2', 'other3'):
    'conditions' => array(
        'type' => array('other', 'other2', 'other3') 
    )
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 BP神经网络控制倒立摆
  • ¥20 要这个数学建模编程的代码 并且能完整允许出来结果 完整的过程和数据的结果
  • ¥15 html5+css和javascript有人可以帮吗?图片要怎么插入代码里面啊
  • ¥30 Unity接入微信SDK 无法开启摄像头
  • ¥20 有偿 写代码 要用特定的软件anaconda 里的jvpyter 用python3写
  • ¥20 cad图纸,chx-3六轴码垛机器人
  • ¥15 移动摄像头专网需要解vlan
  • ¥20 access多表提取相同字段数据并合并
  • ¥20 基于MSP430f5529的MPU6050驱动,求出欧拉角
  • ¥20 Java-Oj-桌布的计算