[英]Check if a relation is loaded in Yii
我正在尝试使用关系执行复杂的操作并避免双重加载:
我有一个object
活动记录,每个都通过objectSubject
关系与某些subject
有关系。
subject
的类型(与object
)在objectSubject
定义了另一种关系。
每个object
具有每种类型的零个或一个subject
关系
我将Object
模型中的关系设置为:
'objectSubjects'=>array(self::HAS_MANY, 'ObjectSubject', 'object_id'),
而ObjectSubject
模型为:
'type'=>array(self::BELONGS_TO, 'Type', 'type_id'),
'subject'=>array(self::BELONGS_TO, 'Subject', 'subject_id'),
我想添加一个函数给Object
通过它的type
获取一个object
的subject
。
我可以:
public function fetchSubject($key_string){
$object_subject=$this->objectSubjects(array(
'with'=>'subject'
'scopes'=>array('typed'=>$key_string) /* Inner Join to type */
));
return $object_subjects?$object_subjects[0]->subject:null;
}
但是这将导致数据库查询,即使具有type
s和subject
s的object_subject
被急切地加载到object
。
我想在它们是的情况下替换逻辑,并且只查询一个subject
行,如果它们不是..有没有办法检查是否已加载关系?
像$this->isLoaded('objectSubjects')
?
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.