首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有find函数的"OR“和" and”数组的Cakephp问题

带有find函数的"OR“和" and”数组的Cakephp问题
EN

Stack Overflow用户
提问于 2013-06-29 22:43:59
回答 1查看 107关注 0票数 1

正如Cakephp的manual所建议的那样,我有一个列,我想在该列上放置"OR“条件,以便将多个值与and条件与其他列进行匹配。

SQL:

代码语言:javascript
复制
SELECT * FROM site_logs 
WHERE action LIKE "Facebook%" OR action LIKE "Twitter%" AND 
created >= "2013-06-29" 
GROUP BY "ip address"

CakePHP:

代码语言:javascript
复制
$conditions = array(
        'OR' => array(
            'SiteLogs.action like' => 'Facebook%'
            'SiteLogs.action like' => 'Twitter%'
        ),
        'SiteLogs.created >=' => '2013-06-29'
    );
 $this->SiteLogs->find('all',
    'conditions' => $conditions,
    'group'     => 'ip address'
 )

生成的SQL只有"twitter“数据的记录,因为"OR”数组包含所有具有相同键的元素,这些元素将相互覆盖。

生成的SQL;

代码语言:javascript
复制
SELECT `site_logs`.* FROM `site_logs` 
WHERE `site_logs`.`action` LIKE "Twitter%" AND  
    site_logs`.`created` >= "2013-06-29" 
GROUP BY `site_logs`.`ip address`

我应该怎么做才能从"OR“数组中获得所有的值?我是不是遗漏了什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-06-29 23:26:55

你要找的是这个。将每个相似的OR子句包含在各自的数组中,以防止键重叠。

代码语言:javascript
复制
$conditions = array(
    'OR' => array(
        array('SiteLogs.action like' => 'Facebook%'),
        array('SiteLogs.action like' => 'Twitter%')
    ),
    'SiteLogs.created >=' => '2013-06-29'
);
$this->SiteLogs->find('all',
    'conditions' => $conditions,
    'group'     => 'ip address'
);

这应该会产生这样的SQL。每个LIKE条件周围都有一组无关的括号,但对于LIKE来说这是不可避免的,而且它根本不会影响查询的执行。

代码语言:javascript
复制
SELECT * 
FROM site_logs 
WHERE 
    ((action LIKE "Facebook%") OR (action LIKE "Twitter%"))
    AND created >= "2013-06-29" 
GROUP BY "ip address"
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17381379

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档