Yii2中hasOne、hasMany及多对多关联查询的用法详解


Posted in PHP onFebruary 15, 2017

前言

hasOne、hasMany是Yii2特有的用于多表关联查询的函数,平时在使用多表关联查询的时候建议使用它们。为什么?因为这种方式关联查询出来的结果会保留Yii2自有的表头排序功能,以及CheckboxColumn中input的id存值,至于还有没有其它的好处就需要大家去挖掘了,笔者目前就发现了这两个常用的好处。其他的关联查询,像yiidbQuery查询或者原生的SQL语句查询都没有,查询出来在列表展示的时候,表头一排黑。

Yii2的hasOne、hasMany多表关联查询,不管是文档还是文章其实都可以轻而易举的找到参考母本,但是笔者为什么还要写这篇文章呢,想法其实也很简单,因为在前面的信息中我没有看到多对多关联查询的用法,不重复别人,也重复自己,本文的重点就讲多对多关联查询的用法,让你涨涨知识。

需求分析

1、使用一条查询语句就能把列表的数据全部展现出来,列表包含一对一,一对多,以及多对多的关系。

2、不能破坏Yii2自有的表头排序功能,以及CheckboxColumn中input的id存值。

效果图

1、一对一,一对多,多对多,表头排序。

Yii2中hasOne、hasMany及多对多关联查询的用法详解

2、CheckboxColumn中input的id值。

Yii2中hasOne、hasMany及多对多关联查询的用法详解

代码分析

多对多

例子:一个客户可以有多个标签,一个标签可以对多个客户。

1、在TSales(客户表的 model)里加入如下代码:

public function getcommon_tag()
 { 
  return $this->hasMany(CommonTag::className(), ['itemid' => 't_id'])->onCondition(['idtype' => "内容"])->joinWith(['tag']);    
 }

注释:这里common_tag表为中间表,common_tag中间表用hasMany与客户表关联之后要在后面加上joinWith(['tag'])关联标签表。onCondition为附加条件的方法。

2、在CommonTag(中间表 model)里加入如下代码关联标签表,用hasOne就行。

public function gettag()
{ 
 return $this->hasOne(Tag::className(), ['id'=>'tagid']);
}

3、在TSalesSearch(客户的Search model) 里加入如下代码关联common_tag中间表: $query->joinWith(['common_tag']);

4、页面输出代码如下:

[
 'attribute' => 'tag_id',
 'value' => function ($model) { 
  $_tag=$model->getRelatedRecords()['common_tag'];
  if(!empty($_tag)){
   $tagName="";
   foreach ($_tag as $key => $value) {                        $tagName.=$value['tag']['name'].'/';
   }
   return rtrim($tagName,'/');
  } 
 },
],

注释:$model->getRelatedRecords() 是用于获取[_related:yiidbBaseActiveRecord:private]数组的值。

一对多

1、在前面的多对多用法中涉及到的hasMany就属于一对多的用法,要实现一对多的话就把后面的joinWith去掉就可以了,其它配置以及输出方式都一样。

一对一

1、一对一的用法前面也涉及了,hasOne就属于一对一的用法,配置和hasMany一样,这里就不详述了。

注意事项

1、当关联查询出来的值使用如下代码输出(common_tag.name)获取不到值的时候,那就应该是你的客户表存在这个name字段,并且这个值为空,重名了之后就会优先输出主表的字段,解决办法用:$model->getRelatedRecords()获取。

[
 'attribute' => 'tag_id',
 'value' => 'common_tag.name'
 ]

以上所述是小编给大家介绍的Yii2中hasOne、hasMany及多对多关联查询的用法详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

PHP 相关文章推荐
PHP 和 XML: 使用expat函数(一)
Oct 09 PHP
几个学习PHP的网址
Nov 25 PHP
Codeigniter注册登录代码示例
Jun 12 PHP
PHP封装的一个支持HTML、JS、PHP重定向的多功能跳转函数
Jun 19 PHP
PH P5.2至5.5、5.6的新增功能详解
Jul 14 PHP
php使用fsockopen函数发送post,get请求获取网页内容的方法
Nov 15 PHP
PHP随机生成唯一HASH值自定义函数
Apr 20 PHP
两款万能的php分页类
Nov 12 PHP
php下载文件超时时间的设置方法
Oct 06 PHP
PHP实现的简单路由和类自动加载功能
Mar 13 PHP
thinkPHP5框架auth权限控制类与用法示例
Jun 12 PHP
thinkPHP5框架实现多数据库连接,跨数据连接查询操作示例
May 29 PHP
详解配置 Apache 服务器支持 PHP 文件的解析
Feb 15 #PHP
PHP使用Redis替代文件存储Session的方法
Feb 15 #PHP
Yii2中多表关联查询hasOne hasMany的方法
Feb 15 #PHP
php+Memcached实现简单留言板功能示例
Feb 15 #PHP
thinkphp3.2中实现phpexcel导出带生成图片示例
Feb 14 #PHP
PHP中Trait及其应用详解
Feb 14 #PHP
php数组指针操作详解
Feb 14 #PHP
You might like
PHP中开启gzip压缩的2种方法
2015/01/31 PHP
PHP实现的注册,登录及查询用户资料功能API接口示例
2017/06/06 PHP
YUI 读码日记之 YAHOO.lang.is*
2008/03/22 Javascript
extjs 学习笔记(三) 最基本的grid
2009/10/15 Javascript
基于jQuery的表格操作插件
2010/04/22 Javascript
纯js实现瀑布流展现照片(自动适应窗口大小)
2013/04/08 Javascript
jquery ajax实现下拉框三级无刷新联动,且保存保持选中值状态
2013/10/29 Javascript
innerHTML在IE中报错解决方案
2014/12/15 Javascript
js计算任意值之间随机数的方法
2015/01/16 Javascript
使用Node.js处理前端代码文件的编码问题
2016/02/16 Javascript
javascript拖拽应用实例
2016/03/25 Javascript
基于Nodejs利用socket.io实现多人聊天室
2017/02/22 NodeJs
详解vue项目首页加载速度优化
2017/10/18 Javascript
小程序二次贝塞尔曲线实现购物车商品曲线飞入效果
2019/01/07 Javascript
vue实现输入一位数字转汉字功能
2019/12/13 Javascript
解决vant-UI库修改样式无效的问题
2020/11/03 Javascript
Python的Bottle框架中实现最基本的get和post的方法的教程
2015/04/30 Python
浅谈Python单向链表的实现
2015/12/24 Python
PyCharm在win10的64位系统安装实例
2017/11/26 Python
python+matplotlib实现动态绘制图片实例代码(交互式绘图)
2018/01/20 Python
python使用itchat实现手机控制电脑
2018/02/22 Python
pycharm远程linux开发和调试代码的方法
2018/07/17 Python
Python 生成器,迭代,yield关键字,send()传参给yield语句操作示例
2019/10/12 Python
Jupyter 无法下载文件夹如何实现曲线救国
2020/04/22 Python
Python多线程thread及模块使用实例
2020/04/28 Python
python实现猜数游戏(保存游戏记录)
2020/06/22 Python
Django模型验证器介绍与源码分析
2020/09/08 Python
政法大学毕业生自荐信范文
2014/01/01 职场文书
构建高效课堂实施方案
2014/03/13 职场文书
《海底世界》教学反思
2014/04/16 职场文书
美术专业自荐信
2014/07/07 职场文书
乡文化站暑期培训方案
2014/08/28 职场文书
英语教师求职信范文
2015/03/20 职场文书
班主任工作总结范文
2015/08/13 职场文书
mysql升级到5.7时,wordpress导数据报错1067的问题
2021/05/27 MySQL
Oracle数据库事务的开启与结束详解
2022/06/25 Oracle