yii2数据库关联查询有哪些方法?
Admin 2021-08-18 群英技术资讯 1499 次浏览
这篇文章主要给大家分享yii2框架数据库关联查询的操作,对大家学习yii2框架具有一定的借鉴价值,感兴趣的朋友可以参考一下,希望大家阅读完这篇文章能有所收获,下面我们一起来学习一下吧。
<?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;
}
总共查询两次。
关于yii2框架数据库关联查询就介绍到这,上述实例具有一定的参考价值,感兴趣的朋友可以参考学习,希望能对大家有帮助,想要了解更多yii2框架的相关内容,大家可以关注其他文章
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在学习PHP过程中,数组是很重要的的一个知识点,对此,这篇文章就给大家介绍一下PHP数组的概念以及基本用法,有这方面学习需要的朋友可以看一下。
PHP论坛实现积分系统的思路代码详解,首先在用户表定义一个积分字段;然后创建一个等级表,主要字段有等级名,上限积分和下限积分;再根据用户的行为进行积分累加;最后根据判断用户积分在哪个等级
这篇文章主要介绍了Thinkphp5.0 框架的请求方式与响应方式,结合实例形式分析了thinkPHP5常见的请求方式与响应方式实现技巧与操作注意事项,需要的朋友可以参考下
thinkphp3有门面类。门面为容器中的类提供了一个静态调用接口,拥有更好的可测试性和扩展性,可以为任何的非静态类库定义一个门面类,语法为“class Test{public function Class(){return路径;}}”。
本文实例讲述了变量的使用和字符串操作,具体实例如下,分享给大家供大家参考,希望大家阅读完这篇能有收获哦,有需要的朋友就往下看吧!
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008