默认yii中ar查询是可以不使用with的,这样会使用延迟加载功能进行对象关联查询,很方便,但是带来了效率问题。
所以考虑使用with进行预加载,但是每当我使用with时就会出现sql错误,查看了error之后发现是因为relations里添加的order,condition,on等条件在生成最终的sql时不会自动加上表别名。
这么说可能大家不太明白,我详细说明一下.
假设结构如下:
class CategoryModel{
function relations() {
return array(
'description' => array(self::HAS_ONE,'CategoryDescription','category_id'),
);
}
function defaultScope() {
return array(
'condition' => 'language=1',
'order' => 'created desc',
);
}
}
class CategoryDescriptionModel{
}
class SiteModel{
function relations() {
return array(
'description' => array(self::HAS_ONE,'SiteDescription','site_id'),
'category' => array(self::BELONGS_TO,'Category','category_id'),
);
}
function defaultScope() {
return array(
'condition' => 'language=1',
'order' => 'created desc',
);
}
}
class SiteDescriptionModel{
}
那么当使用with的时候,created desc会出现歧义,比如.
Site::model()->count();
Site::model()->with('description')->findAll();
Site::model()->with('description','category','category.description');
上面后两个语句中的created desc就会成为语法错误,因为Yii进行了join之后会给表增加alias,所以没有alias的字段名无法识别.
之后我尝试和给所有的model定义alias,然后将scope中的order改为alias.created desc.
但是产生了另一个问题,就是在count()
的时候是没有Join操作的,所以alias.created desc
也不识别而报错了.
官方文档中说scope中的字段要消除歧义,但是我没有找到一个完美的解决办法,除了定义alias之外还有别的么?
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。