前言 hasOne、hasMany是Yii2特有的用于多表关联查询的函数,平时在使用多表关联查询的时候建议使用它们。为什么?因为这种方式关联查询出来的结果会保留Yii2自有的表头排序功能,以及CheckboxColumn中input的id存值,至于还有没有其它的好处就需要大家去挖掘了,笔者目前就发现了这两个常用的好处。其他的关联查询,像yiidbQuery查询或者原生的SQL语句查询都没有,查询出来在列表展示的时候,表头一排黑。 Yii2的hasOne、hasMany多表关联查询,不管是文档还是文章其实都可以轻而易举的找到参考母本,但是笔者为什么还要写这篇文章呢,想法其实也很简单,因为在前面的信息中我没有看到多对多关联查询的用法,不重复别人,也重复自己,本文的重点就讲多对多关联查询的用法,让你涨涨知识。 需求分析1、使用一条查询语句就能把列表的数据全部展现出来,列表包含一对一,一对多,以及多对多的关系。 2、不能破坏Yii2自有的表头排序功能,以及CheckboxColumn中input的id存值。 效果图1、一对一,一对多,多对多,表头排序。 2、CheckboxColumn中input的id值。 多对多 1、在TSales(客户表的 model)里加入如下代码:
2、在CommonTag(中间表 model)里加入如下代码关联标签表,用hasOne就行。
3、在TSalesSearch(客户的Search model) 里加入如下代码关联common_tag中间表: 4、页面输出代码如下:
注释:$model->getRelatedRecords() 是用于获取[_related:yiidbBaseActiveRecord:private]数组的值。 一对多 一对一 1、当关联查询出来的值使用如下代码输出(common_tag.name)获取不到值的时候,那就应该是你的客户表存在这个name字段,并且这个值为空,重名了之后就会优先输出主表的字段,解决办法用:$model->getRelatedRecords()获取。
Yii2中多表关联查询 |
小黑屋|在路上
( 蜀ICP备15035742号-1 )
GMT+8, 2025-7-7 18:30
Copyright 2015-2025 djqfx