繁体   English   中英

Yii2-在整个activeRecords上调用模型函数吗?

[英]Yii2 - Calling model functions on entire activeRecords?

我要做什么

我想使用像这样的活动模型查询一组特定的记录

$jobModel = Jobs::find()->select('JOB_CODE')->distinct()->where(['DEPT_ID'=>$dept_id])->all();

然后,我想根据它们是否出现在关系表中为该activerecord中的记录分配一个标志属性

我尝试过的

因此,在我的工作模型中,我在inAccount声明了一个新属性。 然后,我在作业模型中添加了此函数,该模型根据是否在关系表中找到具有指定account_id的记录,将inAccount标志设置为-1或0

public function assignInAccount($account_id){
    if(JobCodeAccounts::find()->where(['JOB_CODE'=>$this->JOB_CODE])->andWhere(['ACCOUNT_ID'=>$account_id])->one() == null){
        $this->inAccount=0;
    }
    else{
        $this->inAccount = -1;
    }
}

我一直在做的是像这样单独使用foreach分配每个值

foreach($jobModel as $job){
    $job->assignInAccount($account_id);
}

但是,这显然很慢,因为如果我在$jobModel有大量记录,并且每个记录都在assignInAccount()进行数据库查询, assignInAccount()如果数据库很慢,这显然会花费一些时间。

我在寻找什么

我想知道是否有更有效的方法来执行此操作,以便我可以一次将inAccount分配给所有作业记录。 我考虑过使用afterFind()但是我认为这不起作用,因为我需要指定一个特定的参数。 我想知道是否有一种方法可以传递整个模型(或至少传递模型/模型属性数组,然后执行仅在单个查询中进行的所有分配)。

我应该提一下,我确实需要以原始的$jobModel activerecord结尾

感谢scaisEdge的回答,我得以提出一个替代解决方案,首先找到需要标记的作业阵列,如下所示:

    $inAccountJobs = array_column(Yii::$app->db->createCommand('Select * from job_code_accounts where ACCOUNT_ID = :account_id')
        ->bindValues([':account_id' => $account_id])->queryAll(), 'JOB_CODE');

然后检查每个作业记录以查看它是否出现在此数组中,如下所示

    foreach($jobModel as $job){
        if(in_array($job->JOB_CODE, $inAccountJobs))
            $job->inAccount = -1;
        else
            $job->inAccount = 0;
    }

似乎确实要快得多,因为它只需要单个查询。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM