数据库AR之关联查询

来源:互联网 发布:js过渡效果 编辑:程序博客网 时间:2024/06/05 08:58

数据库AR之关联查询

所谓关联查询简单的说就是多表联合查询
AR方式的关联查询比较DAO有一些复杂
并且也有一些小细节 需要了解

  • 数据库AR之关联查询
  • 四种关系
  • 定义
  • 使用
  • 查询条件

四种关系

  1. 多对一 self::BELONGS_TO
  2. 一对一self::HAS_ONE
  3. 一对多self::HAS_MANY
  4. 多对多self::MANY_MANY

定义

在 model中定义对应关系
user.php

public function relations(){    return array(     //关系名称            对应关系 关联的模型(gii创建) 对应的字段     'abcd_city'=>array(self::BELONGS_TO,'City','city_id'),     //字段的对应规则     //要关联的模型中存在 city字段 着关联city字段     //否则 关联主键    );}

使用

懒加载

//到调用的时候 才查询 //不使用 joinpublic 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);}
0 0
原创粉丝点击