数据库AR之关联查询
来源:互联网 发布:js过渡效果 编辑:程序博客网 时间:2024/06/05 08:58
数据库AR之关联查询
所谓关联查询简单的说就是多表联合查询
AR方式的关联查询比较DAO有一些复杂
并且也有一些小细节 需要了解
- 数据库AR之关联查询
- 四种关系
- 定义
- 使用
- 查询条件
四种关系
- 多对一
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字段 //否则 关联主键 );}
使用
懒加载
//到调用的时候 才查询 //不使用 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
- 数据库AR之关联查询
- ORM之数据库关联查询
- Yii2.0框架基础--数据查询之AR类方法 关联查询
- 数据库之AR
- 数据库关联查询说明
- 数据库关联查询
- 关联表查询数据库
- MYSQL数据库关联查询
- 数据库SQL关联查询
- mysql数据库关联查询
- mybatis之关联查询
- MySQL之关联查询
- 关联数据库表多表联合查询
- oracle 关联查询两个数据库
- oracle 数据库查询关联运算
- yii2.0 数据库关联查询
- 数据库多表关联查询
- 数据库多表关联查询
- 【Objective-C】14-内存管理
- Qt菜单和工具条
- 浅谈关键字static和extern
- QT之菜单栏QMenu,下拉菜单QAction,工具栏QToolBar的使用(二)
- 翻译经典之《Cisco Lan Switching》第六章 理解生成树(九):两种BPDU类型
- 数据库AR之关联查询
- Hadoop Hive sql语法详解
- 怎样控制Qt标题栏(How can I handle events in the titlebar and change its color etc ? )
- Android 图像处理软件
- 顺序循环队列的表示和实现(少用一个存储空间)
- Add Binary
- android 中 scollView中嵌套GridView显示UI不全
- Mac OS X10.10 下安装caffe
- Office 2013 中使用 MathType的方法