首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在具有可包含行为的cakePHP中查找条件

在具有可包含行为的cakePHP中查找条件
EN

Stack Overflow用户
提问于 2010-10-11 04:23:19
回答 2查看 3K关注 0票数 0

我有2个模型,用户和进化。用户有很多进化,进化属于用户。

我有10,000个用户,我想做一个条件,让我有500个用户,这些用户在演化表中没有今天的日期。

最初,我取用户表中的每一个,然后我查看它们是否在演进中有自己的行,比如:

代码语言:javascript
复制
$user=$this->User->find('all',array('contain' => array(

                'Evolution' => array('conditions' => array('date'=>$lastupdate))
            ),
        'fields' => array(
            'name',
            'id',
        )
    ));

然后看看有没有发生争执:

代码语言:javascript
复制
if(empty($user['Evolution']))
        {

但我认为,把10000个用户都吸引到500个,这是非常愚蠢的。

我如何才能找到在进化表中没有今天日期的500个用户。

谢谢!!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-10-11 05:15:41

做这样的事情怎么样:

代码语言:javascript
复制
$evolutions = $this->User->Evolution->find('all', 
        array(
             'conditions'=>array('date !='=>$lastupdate),
             'fields'=>array('MAX(date) as max_date', 'user_id', 'User.name', 'User.email'),
             'group'=>array('user_id', 'User.name', 'User.email')
        ),
        'contain'=>array('User'),
        'limit'=>500
)

这样,您可以在演化表中进行搜索,但因为它们是链接的,所以您将拥有每次演化表的用户记录。

如果每天有超过一次的进化,那么问题就来了,但是你可以以某种方式使用MAX()。

票数 1
EN

Stack Overflow用户

发布于 2010-10-11 10:46:13

怎么样

代码语言:javascript
复制
$user=$this->User->find('all',array('contain' => array(

            'Evolution' => array('conditions' => array('date !='=>$lastupdate))
        ),
    'fields' => array(
        'name',
        'id',
    )
    'limit'=>500
));
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3902036

复制
相关文章

相似问题

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