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 相关文章推荐
15个小时----从修改程序到自己些程序
Oct 09 PHP
mysql 全文搜索 技巧
Apr 27 PHP
php设计模式 Composite (组合模式)
Jun 26 PHP
使用Smarty 获取当前日期时间和格式化日期时间的方法详解
Jun 18 PHP
php结合ajax实现赞、顶、踩功能实例
May 12 PHP
PHP中预定义的6种接口介绍
May 12 PHP
微信公众平台开发之天气预报功能
Aug 31 PHP
PHP页面转UTF-8中文编码乱码的解决办法
Oct 20 PHP
php实现网站留言板功能
Nov 04 PHP
PHP接收json 并将接收数据插入数据库的实现代码
Dec 01 PHP
深入理解PHP JSON数组与对象
Jul 19 PHP
PHP基于递归实现的约瑟夫环算法示例
Aug 27 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
动画 《Pokemon Sword·Shield》系列WEB动画《薄明之翼》第2话声优阵容公开!
2020/03/06 日漫
改德生G88 - 加装等响度低音提升电路
2021/03/02 无线电
一些使用频率比较高的php函数
2008/10/03 PHP
php Sql Server连接失败问题及解决办法
2009/08/07 PHP
PHP实现Soap通讯的方法
2014/11/03 PHP
PHP下SSL加密解密、验证、签名方法(很简单)
2020/06/28 PHP
php判断是否为ajax请求的方法
2016/11/29 PHP
yii2安装详细流程
2018/05/23 PHP
使用jQuery轻松实现Ajax的实例代码
2010/08/16 Javascript
js拖拽一些常见的思路方法整理
2014/03/19 Javascript
浅谈Sublime Text 3运行JavaScript控制台
2016/06/06 Javascript
省市选择的简单实现(基于zepto.js)
2016/06/21 Javascript
关于Function中的bind()示例详解
2016/12/02 Javascript
JQuery统计input和textarea文字输入数量(代码分享)
2016/12/29 Javascript
JQuery ZTree使用方法详解
2017/01/07 Javascript
解决vue中修改export default中脚本报一大堆错的问题
2018/08/27 Javascript
vuejs2.0运用原生js实现简单拖拽元素功能
2020/08/21 Javascript
d3绘制基本的柱形图的实现代码
2018/12/12 Javascript
浅谈layui数据表格判断问题(加入表单元素),设置单元格样式
2019/10/26 Javascript
序列化模块json代码实例详解
2020/03/03 Javascript
[51:28]EG vs Mineski 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/16 DOTA
python让图片按照exif信息里的创建时间进行排序的方法
2015/03/16 Python
基于python实现在excel中读取与生成随机数写入excel中
2018/01/04 Python
Python3实现带附件的定时发送邮件功能
2020/12/22 Python
pip install 使用国内镜像的方法示例
2020/04/03 Python
html5 canvas的绘制文本自动换行的示例代码
2018/09/17 HTML / CSS
德国最大的网上鞋店之一:Schuhe24.de
2017/06/10 全球购物
EJB的角色和三个对象
2015/12/31 面试题
贷款担保申请书
2014/05/20 职场文书
会计学专业求职信
2014/07/17 职场文书
计划生育证明格式范本
2014/09/12 职场文书
大学生见习期满自我鉴定
2014/09/13 职场文书
机关副主任个人四风问题整改措施
2014/09/26 职场文书
2014年小学生迎国庆65周年演讲稿
2014/09/27 职场文书
催款函怎么写
2015/06/24 职场文书
导游词之西安骊山
2019/12/03 职场文书