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 28 PHP
php采集文章中的图片获取替换到本地(实现代码)
Jul 08 PHP
PHP中对各种加密算法、Hash算法的速度测试对比代码
Jul 08 PHP
PHP常用处理静态操作类
Apr 03 PHP
php视频拍照上传头像功能实现代码分享
Oct 08 PHP
PHP实现的一致性哈希算法完整实例
Nov 14 PHP
超详细的php用户注册页面填写信息完整实例(附源码)
Nov 17 PHP
PHP获取昨天、今天及明天日期的方法
Feb 03 PHP
Yii2中使用join、joinwith多表关联查询
Jun 30 PHP
PHP简单日历实现方法
Jul 20 PHP
PHP使用strrev翻转中文乱码问题的解决方法
Jan 13 PHP
php实现微信模板消息推送
Mar 30 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中session与cookie的比较
2015/01/27 PHP
php UNIX时间戳用法详解
2017/02/16 PHP
thinkPHP5.0框架URL访问方法详解
2017/03/18 PHP
PDO::quote讲解
2019/01/29 PHP
用js闭包的方法实现多点标注冒泡示例
2014/05/29 Javascript
使用GruntJS构建Web程序之合并压缩篇
2014/06/06 Javascript
JavaScript数组对象实现增加一个返回随机元素的方法
2015/07/27 Javascript
jQuery简单注册和禁用全局事件的方法
2016/07/25 Javascript
深入理解Angular.JS中的Scope继承
2017/06/04 Javascript
Redux 和 Mobx的选择问题:让你不再困惑!
2017/09/18 Javascript
jQuery实现的粘性滚动导航栏效果实例【附源码下载】
2017/10/19 jQuery
vue引入新版 vue-awesome-swiper插件填坑问题
2018/01/25 Javascript
微信小程序列表中item左滑删除功能
2018/11/07 Javascript
bootstrap table实现iview固定列的效果实例代码详解
2019/09/30 Javascript
JS图片预加载三种实现方法解析
2020/05/08 Javascript
VueQuillEditor富文本上传图片(非base64)
2020/06/03 Javascript
Python实现的飞速中文网小说下载脚本
2015/04/23 Python
编写Python脚本来获取mp3文件tag信息的教程
2015/05/04 Python
Python使用logging结合decorator模式实现优化日志输出的方法
2016/04/16 Python
python之Socket网络编程详解
2016/09/29 Python
Python 性能优化技巧总结
2016/11/01 Python
python 为什么说eval要慎用
2019/03/26 Python
Python中的支持向量机SVM的使用(附实例代码)
2019/06/26 Python
Pycharm远程调试原理及具体配置详解
2019/08/08 Python
python matplotlib库绘制条形图练习题
2019/08/10 Python
Python jieba库分词模式实例用法
2021/01/13 Python
pycharm 快速解决python代码冲突的问题
2021/01/15 Python
用CSS3实现无限循环的无缝滚动的示例代码
2017/11/01 HTML / CSS
Book Depository亚太地区:一家领先的国际图书零售商
2019/05/05 全球购物
交通事故协议书
2014/04/15 职场文书
社区活动总结报告
2014/05/05 职场文书
2016年寒假社会实践活动总结
2015/03/27 职场文书
2015年营业员工作总结
2015/04/23 职场文书
导游词之烟台威海蓬莱
2019/11/14 职场文书
Redis 的查询很快的原因解析及Redis 如何保证查询的高效
2022/03/16 Redis