YII框架关联查询操作示例
时间:2022-07-27
本文章向大家介绍YII框架关联查询操作示例,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
本文实例讲述了YII框架关联查询操作。分享给大家供大家参考,具体如下:
以customer order两个表为例
关联查询控制器中
$customer = Customer::find()- where('name'= 'zhangsan')- one();
$orders = $customer- hasmany('orders',['customer_id']= 'id')- asArray()- all();
$orders = $customer- hasmany(Order::className(),['customer_id']= 'id')- asArray()- all();
customer模型中(优化)
public function getOrders(){
$orders = $this- hasmany('orders',['customer_id']= 'id')- asArray()- all();
}
关联查询控制器中就可以这么写
$customer = Customer::find()- where('name'= 'zhangsan')- one();
$orders = $customer- getOrders();
甚至可以这么写
$orders = $customer- orders;
当获取未定义的类属性时会触发类的__get()魔术方法效果 YII会自动调用 getOrders()
方法,而且会加上- all()
,所以定义getOrders()
时不能带上all()
Order模型
public function getCustomer(){
$this- hasOne(Customer::className,['id'= 'customer_id'])- asArray();
}
关联查询控制器中这么写
$order = Order::find()- where("id"= '1')- one();
$customer = $order- customer;
注意点
1.关联查询会被缓存
所以
$customer = Customer::find()- where('name'= 'zhangsan')- one();
unset($customer- orders);//清掉缓存
$order = $customer- orders;
2.关联查询的多次查询
$customers = Customer::find()- all();//select * from customer
foreach($customers as $customer){
$order = $customer- orders;//select * from order where customer_id = ...
}
以上代码执行了101次sql查询,可以进行如下优化
$customers = Customer::find()- with('orders')- all();//select * from customer
foreach($customers as $customer){
$order = $customer- orders();//select * from order where customer_id in (...)
}//变成了2次查询
- 判断js引擎是javascriptCore或者v8
- Springboot系列:Springboot与Thymeleaf模板引擎整合基础教程(附源码)
- 同样的sql执行结果不同的原因分析 (r4笔记第27天)
- 情感分析的新方法,使用word2vec对微博文本进行情感分析和分类
- 垂直属性
- Spring+SpringMVC+MyBatis+easyUI整合进阶篇(二)RESTful API实战笔记(接口设计及Java后端实现)
- 13(02)总结StringBuffer,StringBuilder,数组高级,Arrays,Integer,Character
- Mybatis-Generator生成Mapper文件中<if test="criteria.valid">的问题解答
- Java开源博客My-Blog之mysql容器重复初始化的严重bug修复过程
- 负margin的原理以及应用
- 关于exp/imp的总结学习(r4笔记第26天)
- 除了写烂的手写数据分类,你会不会做自定义图像数据集的识别?!
- shell脚本中字符串的常见操作及"command not found"报错处理(附源码)
- 绝对定位下的盒模型
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- PHP中Session ID的实现原理实例分析
- php5.6.x到php7.0.x特性小结
- android自定义加减按钮
- php链式操作的实现方式分析
- php中的依赖注入实例详解
- Android通知栏前台服务的实现
- Laravel 默认邮箱登录改成用户名登录的实现方法
- Android Studio实现简单计算器APP
- 基于PHP实现微信小程序客服消息功能
- python gstreamer实现视频快进/快退/循环播放功能
- php tpl模板引擎定义与使用示例
- ThinkPHP5&5.1框架关联模型分页操作示例
- Android实现简易计算器(可以实现连续计算)
- PHP实现提高SESSION响应速度的几种方法详解
- ThinkPHP5.1框架数据库链接和增删改查操作示例