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完整的日历类(CLASS)
Nov 27 PHP
PHP读取MySQL数据代码
Jun 05 PHP
PHP 简单日历实现代码
Oct 28 PHP
PHP 开发环境配置(Zend Studio)
Apr 28 PHP
学习使用curl采集curl使用方法
Jan 11 PHP
基于PHP输出缓存(output_buffering)的深入理解
Jun 13 PHP
PHP+Mysql+Ajax+JS实现省市区三级联动
May 23 PHP
php验证手机号码
Nov 11 PHP
PHP模板引擎Smarty中的保留变量用法分析
Apr 11 PHP
利用PHPStorm如何开发Laravel应用详解
Aug 30 PHP
详谈symfony window下的安装 安装时候出现的问题以及解决方法
Sep 28 PHP
PHP PDO数据库操作预处理与注意事项
Mar 16 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语法(5)
2006/10/09 PHP
ThinkPHP结合AjaxFileUploader实现无刷新文件上传的方法
2014/10/29 PHP
php中base64_decode与base64_encode加密解密函数实例
2014/11/24 PHP
PHP关联数组实现根据元素值删除元素的方法
2015/06/26 PHP
从刷票了解获得客户端IP的方法
2015/09/21 PHP
JS去除字符串的空格增强版(可以去除中间的空格)
2009/08/26 Javascript
JQuery中根据属性或属性值获得元素(6种情况获取方法)
2013/01/17 Javascript
超级好用的jQuery圆角插件 Corner速成
2014/08/31 Javascript
触屏中的JavaScript事件分析
2015/02/06 Javascript
javascript实现的闭包简单实例
2015/07/17 Javascript
基于jQuery实现的QQ表情插件
2015/08/25 Javascript
jquery实现简单的表单验证
2015/11/17 Javascript
jqueryMobile 动态添加元素,展示刷新视图的实现方法
2016/05/28 Javascript
JS简单获取当前日期和农历日期的方法
2017/04/17 Javascript
微信小程序中form 表单提交和取值实例详解
2017/04/20 Javascript
bootstrap fileinput组件整合Springmvc上传图片到本地磁盘
2017/05/11 Javascript
30分钟用Node.js构建一个API服务器的步骤详解
2019/05/24 Javascript
JS用最简单的方法实现四舍五入
2019/08/27 Javascript
JS访问对象两种方式区别解析
2020/08/29 Javascript
Python的Django中django-userena组件的简单使用教程
2015/05/30 Python
python查看FTP是否能连接成功的方法
2015/07/30 Python
详谈Python2.6和Python3.0中对除法操作的异同
2017/04/28 Python
python 字典 setdefault()和get()方法比较详解
2019/08/07 Python
使用PyCharm官方中文语言包汉化PyCharm
2020/11/18 Python
沃尔玛加拿大:Walmart.ca
2020/03/02 全球购物
ORACLE第二个十问
2013/12/14 面试题
在C#中如何实现多态
2014/07/02 面试题
采购人员的个人自我评价
2014/01/16 职场文书
小学三年级数学教学反思
2014/01/31 职场文书
2014年办公室个人工作总结
2014/11/12 职场文书
2015国庆节感想
2015/08/04 职场文书
关于国庆节的广播稿
2015/08/19 职场文书
《所见》教学反思
2016/02/23 职场文书
nginx处理http请求实现过程解析
2021/03/31 Servers
Python基础数据类型tuple元组的概念与用法
2021/08/02 Python
MySQL插入数据与查询数据
2022/03/25 MySQL