大佬教程收集整理的这篇文章主要介绍了实例讲解YII2中多表关联的使用方法,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
本文对 YII2.0 的多表关联查询做一个简单的介绍。文中通过实例代码介绍的非常详细,下面话不多说,来一起看看详细的介绍:
表结构
现在有订单表、用户表、商品清单表、商品库存表
// 关联函数以get+要关联的数据表名来命名
// 这是获取下订单的客户
public function getUser(){
// 第一个参数为要关联的子表模型类名,
// 第二个参数指定 通过子表的user_id,关联主表的usesr_id字段
// 这里写清楚点大概意思就是User.user_id => Order.user_id
return $this->hasmany(User::className(),['user_id' => 'user_id']);
}
}
Yii2中的表之间的关联有2种,它们用来指定两个模型之间的关联。
●一对多:hasmany ●一对一:hasOne
●返回结果:这两个方法的返回结果都为yiidBACtiveQuery对象(如果你想最后返回的是标准数组形式,记得加上asArray()参数)
●第一个参数:所关联的模型的类名称。
●第二个参数:是一个数组,其中键为所关联的模型中的属性,值为当前模型中的属性。
现在我们来尝试获取一个订单
当然你可以选择使用with方法,这样看起来简洁一些,其中with的参数为关系的名称,也就在model里面定义的getUser中的user.
●如果以函数的方式调用,会返回一个 ActiveQuery 对象($customer->getorders()->all())
●如果以属性的方式调用,会直接返回模型的结果($customer->orders)
如果这时order表发生了改变,我们希望再次查询的话
再次得到订单的时候你会发现没有变化。原因是只会在第一次执行$order->user的时候才会去数据库里面查询,然后会把结果缓存起来,以后查询的时候都不会再执行sql。
那么如果你想再次执行sql如何做呢?可以执行
下面重点来了!通过上面表结构的图可以看到,User表和Order_goods表示没有直接关联的,那么如果我们想根据用户信息查找这个用户买了哪些商品的话,就势必需要通过Order表去关联两张表。那么该怎么做呢?首先还是model层。因为我们是根据用户去查,所以到User的model层去定义关联。
public function getOrderGoods() {
return $this->hasmany(OrderGoods::className(),['order_id' => 'order_id'])->
via('order');
}
这里注意:getOrderGoods中的第二个order_id是指getOrder关联的Order中的order_id,第一个order_id是指OrderGoods中的order_id。
但是!我们还有最简单的方法,那就是使用sql语句啦!
这样基本就是整个关联部分了
以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对菜鸟教程的支持。
以上是大佬教程为你收集整理的实例讲解YII2中多表关联的使用方法全部内容,希望文章能够帮你解决实例讲解YII2中多表关联的使用方法所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。