数据库AR之关联查询
所谓关联查询简单的说就是多表联合查询
AR方式的关联查询比较DAO有一些复杂
并且也有一些小细节 需要了解
四种关系
- 多对一
self::BELONGS_TO
- 一对一
self::HAS_ONE
- 一对多
self::HAS_MANY
- 多对多
self::MANY_MANY
定义
在 model中定义对应关系
user.php
public function relations()
{
return array(
//关系名称 对应关系 关联的模型(gii创建) 对应的字段
'abcd_city'=>array(self::BELONGS_TO,'City','city_id'),
//字段的对应规则
//要关联的模型中存在 city字段 着关联city字段
//否则 关联主键
);
}
使用
懒加载
//到调用的时候 才查询
//不使用 join
public function actionLazyRead()
{
$user = User::model()->find();
//此时 还没有去数据库查找
//此时采取数据库去查询
//查询方式通过 user表中中对应的city_id 去city表中查询
var_dump($user->abcd_city);
}
渴望加载
//直接 join数据
public function actionEagerRead()
{
//此时数据已经被查出
//通过 join的方式查出
$user = User::model()->with('abcd_city')->find();
var_dump($user);
}
查询条件
user.php
public function relations()
{
return array(
// 添加别名 'abcd_city'=>array(self::BELONGS_TO,'City','city','alias'=>'c'),
);
}
当前模型别名默认为t
public function actionEagerRead()
{
//此时数据已经被查出
//通过 join的方式查出
$criteria = new CDbCriteria();
//当前模型的别名 默认为 t
$criteria->addCondition('t.id > 5 AND t.id < 10');
$criteria->order = 't.id desc';
$criteria->addCondition('c.id < 4');
$user = User::model()->with('abcd_city')->findAll($criteria);
var_dump($user);
}