gpt4 book ai didi

activerecord - yii2 按关系列获取事件记录

转载 作者:行者123 更新时间:2023-12-04 04:36:24 24 4
gpt4 key购买 nike

我需要选择具有特定列值的相关 AR 的 ActiveRecord

情况:“用户”可能有许多“分支机构”——通过联结表,分支机构与部门相关。我有 department_id,我想选择从这个部门有分支的用户。

部门:

... $this->hasMany(Branch::className(), ['department_id' => 'id']);

分支:

... $this->hasMany(User::className(), ['id' => 'user_id'])
->viaTable('{{%user_to_branch}}',['branch_id' => 'id']);

问题是,我不想以任何方式从部门访问它(例如 $department->getUsers()....),但我想在 ActiveQuery

所以我可以选择像这样的用户:

User::find()->fromDepartment(5)->all();

提前致谢!

最佳答案

在 ActiveRecord 中:

/**
* @inheritdoc
* @return MyActiveRecordModelQuery the active query used by this AR class.
*/
public static function find()
{
return new MyActiveRecordModelQuery(get_called_class());
}

MyActiveRecordModelQuery:

/**
* @method MyActiveRecordModelQuery one($db = null)
* @method MyActiveRecordModelQuery[] all($db = null)
*/
class MyActiveRecordModelQuery extends ActiveQuery
{
/**
* @return $this
*/
public function fromDepartment($id)
{
$this->andWhere(['departament_id' => $id]); //or use relation

return $this;
}
}

用法:

MyActiveRecordModelQuery::find()->fromDepartment(5)->all();

关于activerecord - yii2 按关系列获取事件记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33018381/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com