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实现的简单压缩英文字符串的代码
Apr 24 PHP
PHP采集利器 Snoopy 试用心得
Jul 03 PHP
php中jQuery插件autocomplate的简单使用笔记
Jun 14 PHP
PHP批量采集下载美女图片的实现代码
Jun 03 PHP
Thinkphp模板中截取字符串函数简介
Jun 17 PHP
Linux下创建nginx脚本-start、stop、reload…
Aug 03 PHP
php源码分析之DZX1.5随机数函数random用法
Jun 17 PHP
PHP读取汉字的点阵数据
Jun 22 PHP
YII Framework框架教程之使用YIIC快速创建YII应用详解
Mar 15 PHP
9个比较实用的php代码片段
Mar 15 PHP
php while循环控制的简单实例
May 30 PHP
smarty模板的使用方法实例分析
Sep 18 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
模拟xcopy的函数
2006/10/09 PHP
中英文字符串翻转函数
2008/12/09 PHP
用PHP写的基于Memcache的Queue实现代码
2011/11/27 PHP
[原创]PHP实现字节数Byte转换为KB、MB、GB、TB的方法
2017/08/31 PHP
form中限制文本字节数js代码
2007/06/10 Javascript
JavaScript中的Location地址对象
2008/01/16 Javascript
非阻塞动态加载javascript广告实现代码
2010/11/17 Javascript
jQuery验证Checkbox是否选中的代码 推荐
2011/09/04 Javascript
jQuery编辑器KindEditor4.1.4代码高亮显示设置教程
2013/03/01 Javascript
javascript实现页面内关键词高亮显示代码
2014/04/03 Javascript
jquery 实现input输入什么div图层显示什么
2014/06/15 Javascript
JavaScript事件处理的方式(三种)
2016/04/26 Javascript
开启BootStrap学习之旅
2016/05/04 Javascript
基于Echarts 3.19 制作常用的图形(非静态)
2016/05/19 Javascript
BootStrap智能表单实战系列(七)验证的支持
2016/06/13 Javascript
微信小程序开发之toast提示插件使用示例
2017/06/08 Javascript
node基于puppeteer模拟登录抓取页面的实现
2018/05/09 Javascript
详解Require.js与Sea.js的区别
2018/08/05 Javascript
Vuejs+vue-router打包+Nginx配置的实例
2018/09/20 Javascript
微信小程序自定义带价格显示日历效果
2018/12/29 Javascript
vue+导航锚点联动-滚动监听和点击平滑滚动跳转实例
2019/11/13 Javascript
微信小程序加载机制及运行机制图解
2019/11/27 Javascript
小谈angular ng deploy的实现
2020/04/07 Javascript
javascript实现文字跑马灯效果
2020/06/18 Javascript
python不带重复的全排列代码
2013/08/13 Python
Java多线程编程中ThreadLocal类的用法及深入
2016/06/21 Python
Python 模块EasyGui详细介绍
2017/02/19 Python
python OpenCV学习笔记实现二维直方图
2018/02/08 Python
Python中文件的读取和写入操作
2018/04/27 Python
python通过matplotlib生成复合饼图
2020/02/06 Python
城管综合整治方案
2014/05/01 职场文书
英文演讲稿
2014/05/15 职场文书
民主评议党员自我评价材料
2014/09/18 职场文书
毕业生求职自荐信(2016最新版)
2016/01/28 职场文书
找规律教学反思
2016/02/23 职场文书
Vue如何清空对象
2022/03/03 Vue.js