数据库AR之关联查询

数据库AR之关联查询

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

四种关系

  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字段
     //否则 关联主键
    );
}

使用

懒加载

//到调用的时候 才查询 
//不使用 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);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值