准备条件:

1、首先准备两张表:

customer(用户表)(id, name)

order(订单表)(id, customer_id, price)

customer 表和 order 表之间是一对多的关系,通过 customer_id 字段关联。

2、建立相应的模型文件 customer.php 和 order.php 文件。

关联查询:

customer.php文件添加getOrder()方法:

<?php

namespace app\models;

use Yii;

/**
* This is the model class for table "customer".
*
* @property int $id
* @property string $name 用户姓名
*/
class Customer extends \yii\db\ActiveRecord
{
/**
* 获取订单信息
*/
public function getOrder()
{
// 一个用户对应多个订单,一对多的关系使用hasMany()关联
return $this->hasMany(Order::className(), ['customer_id' => 'id'])->asArray();
} }

order.php文件添加getCustomer()方法:

<?php

namespace app\models;

use Yii;

/**
* This is the model class for table "order".
*
* @property int $id
* @property int $customer_id 用户id
* @property string $price 价格
*/
class Order extends \yii\db\ActiveRecord
{
/**
* 获取用户信息
*/
public function getCustomer()
{
// 一个订单对应一个用户,一对一的关系使用hasOne()关联
return $this->hasOne(Customer::className(), ['id' => 'customer_id'])->asArray();
}
}

使用:

// 查询客户名为张三的订单信息
$customer = Customer::find()->where(['name' => '张三'])->one();
// 可以通过$customer->getOrder()方法调用customer.php模型中getOrder()方法
$orders = $customer->getOrder()->all();
// 也可以使用$customer->order属性调用,
// 当程序没有找到order属性时,PHP会调用__get()函数,程序会自动寻找getOrder()方法调用
// 这里不用加all(),程序会自动识别,如果使用的是hasMany则加all(),hasOne则加上one()
$orders = $customer->order;
var_dump($orders);exit; // 查询订单id为1的客户信息
$order = Order::find()->where(['id' => 1])->one();
// 调用order.php模型中getCustomer()方法
$customer = $order->customer;
var_dump($customer);exit;

with 和 joinWith 的使用:

使用上面的关联查询时有个问题就是数据量大的时候性能问题。

$customers = Customer::find()->all();   // 相当于执行 select * from customer
foreach ($customers as $customer) {
$orders = $customer->order; // 相当于执行 select * from order where customer_id = id;
}

假如$customers中有100条数据,则要循环查询100次,整个程序需要执行SQL语句101次。

这时可以使用with():

// 相当于执行了两条SQL语句 select * from customer
// select * from order where customer_id in(...)
$customers = Customer::find()->with('order')->asArray()->all();
foreach ($customers as $customer) {
$orders = $customer['order']; // 取得order表的关联数据
}

joinWith()的用法和with()差不多,joinWith()可以指定连接类型,默认LEFT JOIN连接。

注意点:

1、在模型中定义hasMany,hasOne方法时,最好不要加上all(),one()。调用$customer->order时程序会自动根据使用的是hasMany还是hasOne加上相应的all(), one()。

2、使用with(), joinWith() 查询时,如果在模型中定义hasMany,hasOne方法时加上了all(),one(),程序会报错。

Yii2中多表关联查询的更多相关文章

  1. Yii2中多表关联查询(join、joinwith)

    我们用实例来说明这一部分 表结构 现在有客户表.订单表.图书表.作者表, 客户表Customer   (id  customer_name) 订单表Order      (id  order_name ...

  2. [moka同学笔记]Yii2中多表关联查询(join、joinwith) (摘录)

    表结构 现在有客户表.订单表.图书表.作者表, 客户表Customer   (id  customer_name) 订单表Order          (id  order_name       cu ...

  3. Yii2.0中文开发向导——Yii2中多表关联查询(join、joinwith)(转)

    我们用实例来说明这一部分 表结构 现在有客户表.订单表.图书表.作者表, 客户表Customer   (id  customer_name) 订单表Order          (id  order_ ...

  4. Yii2.0中文开发向导——Yii2中多表关联查询(join、joinwith)

    我们用实例来说明这一部分 表结构 现在有客户表.订单表.图书表.作者表, 客户表Customer   (id  customer_name) 订单表Order          (id  order_ ...

  5. Yii2中多表关联查询(hasOne、hasMany、join、joinwith)

    表结构 现在有客户表.订单表.图书表.作者表, 客户表Customer   (id  customer_name) 订单表Order      (id  order_name  customer_id ...

  6. Yii2中多表关联查询(with、join、joinwith)

    表结构 现在有客户表.订单表.图书表.作者表, 客户表Customer   (id  customer_name) 订单表Order         (id  order_name   custome ...

  7. RDIFramework.NET 中多表关联查询分页实例

    RDIFramework.NET 中多表关联查询分页实例 RDIFramework.NET,基于.NET的快速信息化系统开发.整合框架,给用户和开发者最佳的.Net框架部署方案.该框架以SOA范式作为 ...

  8. MyBatis 中两表关联查询MYSQL (14)

    MyBatis 中两表关联查询MYSQL 1.创建数据库表语句 2.插入测试数据 3.pom文件内容 <?xml version="1.0" encoding="U ...

  9. 【SQL】在SQL Server中多表关联查询问题

    好久没有写SQL语句的多表连接查询,总在用框架进行持久化操作.今天写了一个多表关联查询,想根据两个字段唯一确定一条数据 失败的案例如下: SELECT cyb.id,ad.name FROM [Gen ...

随机推荐

  1. 爬取豆瓣top250音乐 时长 出版商 存入Mongo数据库

    import requestsfrom lxml import etreeimport reimport pymongoimport time client = pymongo.MongoClient ...

  2. python_thread

    多任务编程:可以有效的利用计算机资源,同时执行多个任务进程:进程就是程序在计算机中一次执行的过程进程 和 程序的区别:    1.程序是一个静态文件的描述,不占计算机的系统资源    2.进程是一个动 ...

  3. tabBarItem是模型,只有控件才有textColor属性

    如果通过模型设置控件的文字颜色,只能通过文本属性(富文本:颜色,字体,图文混排,空心)

  4. element table 先显示暂无数据 之后再加载数据 问题

    项目中的表格请求数据时,进去页面,先出现 ''暂无数据'' 字样闪现一下之后在进行加载数据,用户体验十分不好 解决办法: <template> <el-table :data=&qu ...

  5. echarts 堆叠柱状图 + 渐变柱状图

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. MDS 多活配置

    CephFS 介绍及使用经验分享 阅读 1179 收藏 2 2019-01-14 原文链接:www.jianshu.com WebRTC SFU中发送数据包的丢失反馈juejin.im 目录 Ceph ...

  7. 从源码看Nacos的设计

    目录 客户端与集群的交互 数据同步 实例信息同步 服务集群信息 关于priv-raft协议 Nacos集群在k8s中的实践 这片博文来源于我在公司部门内的分享,我隐去了和公司项目相关的部分,重新整理, ...

  8. rails 5 功能新增及改变

    1.ApplicationRecord 在Rails4中所有的模型都继承自ActiveRecord::Base,不过在Rails5中新引进了一个叫ApplicationRecord的类,存放在: ap ...

  9. inline以及inline-block行内元素:vertical-align属性

  10. 改进一条Group By

    1.先回顾下基础知识: Group By 对数据分组聚合,常常伴随having使用.having可以处理单记录,也可以小组为单位处理. 语句: SELECT colFROM table[WHERE][ ...