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 相关文章推荐
杏林同学录(三)
Oct 09 PHP
PHP+AJAX实现无刷新注册(带用户名实时检测)
Dec 02 PHP
获得Google PR值的PHP代码
Jan 28 PHP
PHP开发中常用的三个表单验证函数使用小结
Mar 03 PHP
Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 2611816 bytes)
Nov 08 PHP
Laravel中扩展Memcached缓存驱动实现使用阿里云OCS缓存
Feb 10 PHP
php获取文件名后缀常用方法小结
Feb 24 PHP
WordPress主题制作之模板文件的引入方法
Dec 28 PHP
Yii净化器CHtmlPurifier用法示例(过滤不良代码)
Jul 15 PHP
PHP Socket网络操作类定义与用法示例
Aug 30 PHP
PHP匿名函数(闭包函数)详解
Mar 22 PHP
PHP数组基本用法与知识点总结
Jun 02 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生成excel列名超过26列大于Z时的解决方法
2014/12/29 PHP
PHP常用的排序和查找算法
2015/08/06 PHP
html数组字符串拼接的最快方法
2009/09/16 Javascript
JavaScript的类型转换(字符转数字 数字转字符)
2010/08/30 Javascript
浅析jQuery的链式调用之each函数
2010/12/03 Javascript
时间戳转换为时间 年月日时间的JS函数
2013/08/19 Javascript
jquery cookie实现的简单换肤功能适合小网站
2013/08/25 Javascript
javascript中hasOwnProperty() 方法使用指南
2015/03/09 Javascript
jQuery调用ajax请求的常见方法汇总
2015/03/24 Javascript
js实现用户离开页面前提示是否离开此页面的方法(包括浏览器按钮事件)
2015/07/18 Javascript
jquery插件jquery.nicescroll实现图片无滚动条左右拖拽的方法
2015/08/10 Javascript
js实现对ajax请求面向对象的封装
2016/01/08 Javascript
JavaScript制作简易计算器(不用eval)
2017/02/05 Javascript
js清除浏览器缓存的几种方法
2017/03/15 Javascript
vue中的数据绑定原理的实现
2018/07/02 Javascript
微信小程序拼接图片链接无底洞深入探究
2019/09/03 Javascript
[02:38]DOTA2超级联赛专访Loda 认为IG世界最强
2013/05/27 DOTA
Python去除列表中重复元素的方法
2015/03/20 Python
Python的包管理器pip更换软件源的方法详解
2016/06/20 Python
Python如何为图片添加水印
2016/11/25 Python
Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能示例
2017/08/31 Python
python如何爬取个性签名
2018/06/19 Python
Python批量查询关键词微信指数实例方法
2019/06/27 Python
Django实现微信小程序的登录验证功能并维护登录态
2019/07/04 Python
新手入门学习python Numpy基础操作
2020/03/02 Python
python产生模拟数据faker库的使用详解
2020/11/04 Python
让IE6、IE7、IE8支持CSS3的脚本
2010/07/20 HTML / CSS
提供世界各地便宜的机票:Sky-tours
2016/07/21 全球购物
Nayomi官网:沙特阿拉伯王国睡衣和内衣品牌
2020/12/19 全球购物
法院实习人员自我鉴定
2013/09/26 职场文书
成品仓管员工作职责
2013/12/29 职场文书
优秀少先队工作者事迹材料
2014/05/13 职场文书
消防工作实施方案
2014/06/09 职场文书
火锅店的活动方案
2014/08/15 职场文书
工程索赔意向书
2014/08/30 职场文书
2014年数学教师工作总结
2014/12/03 职场文书