我有2个模型,用户和进化。用户有很多进化,进化属于用户。
我有10,000个用户,我想做一个条件,让我有500个用户,这些用户在演化表中没有今天的日期。
最初,我取用户表中的每一个,然后我查看它们是否在演进中有自己的行,比如:
$user=$this->User->find('all',array('contain' => array(
'Evolution' => array('conditions' => array('date'=>$lastupdate))
),
'fields' => array(
'name',
'id',
)
));然后看看有没有发生争执:
if(empty($user['Evolution']))
{但我认为,把10000个用户都吸引到500个,这是非常愚蠢的。
我如何才能找到在进化表中没有今天日期的500个用户。
谢谢!!
发布于 2010-10-11 05:15:41
做这样的事情怎么样:
$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()。
发布于 2010-10-11 10:46:13
怎么样
$user=$this->User->find('all',array('contain' => array(
'Evolution' => array('conditions' => array('date !='=>$lastupdate))
),
'fields' => array(
'name',
'id',
)
'limit'=>500
));https://stackoverflow.com/questions/3902036
复制相似问题