yii 之数据库关联查询
<?php
namespace app\controllers;
use yii\web\Controller;
use app\models\Customer; class CustomerController extends Controller{ //根据顾客名字查询出所有的订单信息
public function actionIndex(){
$customer = Customer::find()->where(['name'=>'zhangsan'])->one();
$orders = $customer->hasMany('app\models\Order',['customer_id'=>'id'])->asArray()->all();
print_r($orders);
}
} ?>
上边的控制器方法查询,Customer模型没有具体方法。
上边的 app\models\Order 可以改进为Order::className(),并且上边要添加use app\models\Order;
方式二:(使用model方法)
customer模型代码:
<?php
namespace app\models;
use yii\db\ActiveRecord;
class Customer extends ActiveRecord{ public function getOrders(){
return $this->hasMany(Order::className(),['customer_id'=>'id'])->asArray()->all();
}
}
控制器代码:
namespace app\controllers;
use yii\web\Controller;
use app\models\Customer; class CustomerController extends Controller{ //根据顾客名字查询出所有的订单信息
public function actionIndex(){
$customer = Customer::find()->where(['name'=>'zhangsan'])->one();
$orders = $customer->getOrders();
print_r($orders);
}
}
方法三:(调用模型的属性查询)
customer模型代码:
namespace app\models;
use yii\db\ActiveRecord;
class Customer extends ActiveRecord{ public function getOrders(){
return $this->hasMany(Order::className(),['customer_id'=>'id'])->asArray();
}
}
控制器代码:
namespace app\controllers;
use yii\web\Controller;
use app\models\Customer; class CustomerController extends Controller{ //根据顾客名字查询出所有的订单信息
public function actionIndex(){
$customer = Customer::find()->where(['name'=>'zhangsan'])->one();
$orders = $customer->orders;
//说明,当调用一个不存在的属性时,
//php会去调用一个__get()的方法,
//__get()的方法会自动调用一个get+属性的方法,即getOrders()
//并且会再查询时自动补上->all()或->one()方法,根据模型查询的hasMany或hasOne决定的
print_r($orders);
}
}
根据订单id获取对应的顾客信息:
模型代码:
namespace app\models;
use yii\db\ActiveRecord;
class Order extends ActiveRecord{ //根据订单id获取顾客信息
public function getCustomer(){
return $this->hasOne(Customer::className(),['id'=>'customer_id'])->asArray();
} }
控制器代码:
namespace app\controllers;
use yii\web\Controller;
use app\models\Order; class CustomerController extends Controller{ //根据订单查询用户信息
public function actionIndex(){
$orders = Order::find()->where(['id'=>2])->one();
$customer = $orders->customer;
print_r($customer);
}
}
以上代码中的$orders->customer会记录缓存,如果要删除缓存,可以使用unset($orders->customer)。
关联查询的多次查询
$customers = Customer::find()->all();
foreach($customers as $customer){
$orders = $customer->orders;
}
这样如果有100条数据,就总共需要查询101次。
优化:
$customers = Customer::find()->with('orders')->all();
foreach($customers as $customer){
$orders = $customer->orders;
}
总共查询两次。
yii 之数据库关联查询的更多相关文章
- Yii2实现跨mysql数据库关联查询排序功能
遇到一个项目,需要跨表网上找了很多的资料,整理一下,方便以后再次使用 背景:在一个mysql服务器上(注意:两个数据库必须在同一个mysql服务器上)有两个数据库: memory (存储常规数据表) ...
- MySQL查询(关联查询)
一.mysql查询与权限 (一)数据库关联查询 **内连接查询(inner join)** 查询两个表共有的数据,交集 SELECT * FROM tb1 INNER JOIN tb2 ON 条件 所 ...
- 如何玩转跨库Join?跨数据库实例查询应用实践
背景 随着业务复杂程度的提高.数据规模的增长,越来越多的公司选择对其在线业务数据库进行垂直或水平拆分,甚至选择不同的数据库类型以满足其业务需求.原本在同一数据库实例里就能实现的SQL查询,现在需要跨多 ...
- Mybatis关联查询和数据库不一致问题分析与解决
Mybatis关联查询和数据库不一致问题分析与解决 本文的前提是,确定sql语句没有问题,确定在数据库中使用sql和项目中结果不一致. 在使用SpringMVC+Mybatis做多表关联时候,发现也不 ...
- Oracle 数据库(oracle Database)Select 多表关联查询方式
Oracle数据库中Select语句语法及介绍 SELECT [ ALL | DISTINCT ] <字段表达式1[,<字段表达式2[,…] FROM <表名1>,<表名 ...
- YII关联查询
原文链接:http://keshion.iteye.com/blog/1607994 一.多表关联的配置 在我们使用 AR 执行关联查询之前,我们需要让 AR 知道一个 AR 类是怎样关联到另一个的. ...
- [Oracle] 关系型数据库排序算法和数据结构以及关联查询
关系型数据库排序算法和数据结构以及关联查询 1. Merge sort 理解merge sort算法将有助于更好地理解数据库join操作 - merge join 算法逻辑 将2个有序的大小为N/2的 ...
- Yii关联查询(转载)
原文链接:http://keshion.iteye.com/blog/1607994 一.多表关联的配置 在我们使用 AR 执行关联查询之前,我们需要让 AR 知道一个 AR 类是怎样关联到另一个的. ...
- day95:flask:SQLAlchemy数据库查询进阶&关联查询
目录 1.数据库查询-进阶 1.常用的SQLAlchemy查询过滤器 2.常用的SQLAlchemy查询结果的方法 3.filter 4.order_by 5.count 6.limit&of ...
随机推荐
- (八)VMware harbor 成员管理
(一)VMware harbor 成员管理 可以给项目添加成员,成员必须是已经注册的成员. 添加成员后,成员就会有4种角色:项目管理员,维护人员,开发人员,访客. 1.1 新建成员 1.2 修改角色 ...
- Web开发者必须知道的10个jQuery代码片段
在过去的几年中,jQuery一直是使用最为广泛的JavaScript脚本库.今天我们将为各位Web开发者提供10个最实用的jQuery代码片段,有需要的开发者可以保存起来. 1.检测Internet ...
- python_111_动态导入模块
lib下aa.py文件内容: class C: def __init__(self): self.name='alex' from lib import aa#正常导入 print(aa.C) 动态导 ...
- QR 分解
将学习到什么 介绍了平面旋转矩阵,Householder 矩阵和 QR 分解以入相关性质. 预备知识 平面旋转与 Householder 矩阵是特殊的酉矩阵,它们在建立某些基本的矩阵分解过程中起着 ...
- python基础面试题整理---从零开始 每天十题(01)
最近在弄flask的东西,好久没写博客的,感觉少了点什么,感觉被别人落下好多,可能渐渐的养成了写博客的习惯吧.也是自己想学的东西太多了(说白了就是基础太差了,只是know how,不能做到konw w ...
- linux虚拟机安装值得注意的几点
1.建立新的虚拟机时选择自定义安装并选择稍后安装操作系统 2.关键安装命令 tar -xzvf VMwareTools-10.0.6-3595377.tar.gz sudo ./wmware-ins ...
- scanf函数详解
函数名: scanf 功 能: 执行格式化输入 用 法: int scanf(char *format[,argument,...]);scanf()函数是通用终端格式化输入函数,它从标准输入设备(键 ...
- python多进程与多线程编程
进程(process)和线程(thread)是非常抽象的概念.多线程与多进程编程对于代码的并发执行,提升代码运行效率和缩短运行时间至关重要.下面介绍一下python的multiprocess和thre ...
- (33)zabbix proxy分布式监控配置
概述 zabbix proxy可以代替zabbix server检索客户端的数据,然后把数据汇报给zabbix server,并且在一定程度上分担了zabbix server的压力.zabbix pr ...
- js中小数精度问题
js中小数的取值为近似值,可能比实际值大,也可能比实际值小,进行“四舍五入”得到的 例如:alert(0.1+0.2);值为0.300000004 alert(0.2+0.7);值为1.899 ...