主页 > 知识库 > YII框架关联查询操作示例

YII框架关联查询操作示例

热门标签:开发地图标注类网站 百度地图标注偏差 电销机器人问门萨维品牌my 广东广州在怎么申请400电话 外呼系统能给企业带来哪些好处 百度地图怎样标注图标 余姚电话机器人 400电话兰州申请请 咸宁销售电销机器人系统

本文实例讲述了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次查询

更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

您可能感兴趣的文章:
  • Yii2增删改查之查询 where参数详细介绍
  • Yii多表联合查询操作详解
  • YII2数据库查询实践
  • yii数据库的查询方法
  • Yii2中多表关联查询hasOne hasMany的方法
  • 详解YII关联查询
  • Yii2.0表关联查询实例分析
  • 详解Yii2.0使用AR联表查询实例
  • Yii框架连表查询操作示例
  • Yii框架数据库查询、增加、删除操作示例
  • Yii框架where查询用法实例分析

标签:衡阳 鹰潭 临沂 巴彦淖尔 重庆 丽江 铜陵 十堰

巨人网络通讯声明:本文标题《YII框架关联查询操作示例》,本文关键词  YII,框架,关联,查询,操作,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《YII框架关联查询操作示例》相关的同类信息!
  • 本页收集关于YII框架关联查询操作示例的相关信息资讯供网民参考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推荐文章