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
默默简单的写了一个模板引擎
Jan 02 PHP
php实现aes加密类分享
Feb 16 PHP
php通过数组实现多条件查询实现方法(字符串分割)
May 06 PHP
php实现zip压缩文件解压缩代码分享(简单易懂)
May 10 PHP
PHP中使用json数据格式定义字面量对象的方法
Aug 20 PHP
php判断linux下程序问题实例
Jul 09 PHP
PHP编写文件多服务器同步程序
Jul 02 PHP
php基于curl实现的股票信息查询类实例
Nov 11 PHP
使用php自动备份数据库表的实现方法
Jul 28 PHP
解决Laravel无法使用COOKIE和SESSION的问题
Oct 16 PHP
Laravel6.18.19如何优雅的切换发件账户
Jun 14 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 curl CURLOPT_RETURNTRANSFER参数的作用使用实例
2015/02/07 PHP
php curl 获取https请求的2种方法
2015/04/27 PHP
PHP递归实现层级树状展开
2016/04/01 PHP
PHP实现redis限制单ip、单用户的访问次数功能示例
2018/06/16 PHP
PHP操作Redis数据库常用方法示例
2018/08/25 PHP
ASP SQL防注入的方法
2008/12/25 Javascript
js Event对象的5种坐标
2011/09/12 Javascript
javascript中input中readonly和disabled区别介绍
2012/10/23 Javascript
图片无缝滚动代码(向左/向下/向上)
2013/04/10 Javascript
javascript ajax的5种状态介绍
2014/08/18 Javascript
JQUERY简单按钮轮换选中效果实现方法
2015/05/07 Javascript
个人网站留言页面(前端jQuery编写、后台php读写MySQL)
2016/05/03 Javascript
深入探讨Vue.js组件和组件通信
2016/09/12 Javascript
js 能实现监听F5页面刷新子iframe 而父页面不刷新的方法
2016/11/09 Javascript
详解动画插件wow.js的使用方法
2017/09/13 Javascript
vue 数组和对象不能直接赋值情况和解决方法(推荐)
2017/10/25 Javascript
初识 Vue.js 中的 *.Vue文件
2017/11/22 Javascript
关于微信公众号开发无法支付的问题解决
2018/12/28 Javascript
详解用python实现简单的遗传算法
2018/01/02 Python
python逐行读写txt文件的实例讲解
2018/04/03 Python
在自动化中用python实现键盘操作的方法详解
2019/07/19 Python
Python实现时间序列可视化的方法
2019/08/06 Python
Python分类测试代码实例汇总
2020/07/23 Python
如何解决python多种版本冲突问题
2020/10/13 Python
python 实现全球IP归属地查询工具
2020/12/18 Python
基于html5 DeviceOrientation 实现微信摇一摇功能
2015/09/25 HTML / CSS
Molton Brown美国官网:奢华美容、香水、沐浴和身体护理
2020/09/02 全球购物
资料员的岗位职责
2013/11/20 职场文书
农村改厕实施方案
2014/03/22 职场文书
预备党员承诺书
2014/03/25 职场文书
夫妻分居协议书范文
2014/11/26 职场文书
大足石刻导游词
2015/02/02 职场文书
2015年农村党员公开承诺事项
2015/04/28 职场文书
开会迟到检讨书范文
2015/05/06 职场文书
2015年财务科工作总结范文
2015/05/13 职场文书
python pygame入门教程
2021/06/01 Python