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 相关文章推荐
生成sessionid和随机密码的例子
Oct 09 PHP
PHP 远程关机实现代码
Nov 10 PHP
PHP中去掉字符串首尾空格的方法
May 19 PHP
浅析php面向对象public private protected 访问修饰符
Jun 30 PHP
php接口与接口引用的深入解析
Aug 09 PHP
win7计划任务定时执行PHP脚本设置图解
May 09 PHP
Zend Framework缓存Cache用法简单实例
Mar 19 PHP
php基于openssl的rsa加密解密示例
Jul 11 PHP
通过chrome浏览器控制台(Console)进行PHP Debug的方法
Oct 19 PHP
php通过pecl方式安装扩展的实例讲解
Feb 02 PHP
Bootstrap+PHP实现多图上传功能实例详解
Apr 08 PHP
php扩展开发入门demo示例
Sep 23 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 大数据量及海量数据处理算法总结
2011/05/07 PHP
async和DOM Script文件加载比较
2014/07/20 PHP
PHP连接操作access数据库实例
2015/03/30 PHP
PHP编译安装时常见错误解决办法
2015/05/28 PHP
详解yii2使用多个数据库的案例
2017/06/16 PHP
详解Yaf框架PHPUnit集成测试方法
2017/12/27 PHP
laravel自定义分页的实现案例offset()和limit()
2019/10/15 PHP
JScript分割字符串示例代码
2013/09/04 Javascript
实现动画效果核心方式的js代码
2013/09/27 Javascript
web css实现整站样式互相切换
2013/10/29 Javascript
js判断元素是否隐藏的方法
2014/06/09 Javascript
JavaScript跨浏览器获取页面中相同class节点的方法
2015/03/03 Javascript
jQuery插件jPaginate实现无刷新分页
2015/05/04 Javascript
jQuery中show与hide方法用法示例
2016/09/16 Javascript
Vue路由跳转问题记录详解
2017/06/15 Javascript
使用Ajax和Jquery配合数据库实现下拉框的二级联动的示例
2018/01/25 jQuery
vue+django实现一对一聊天功能的实例代码
2019/07/17 Javascript
关于vue3.0中的this.$router.replace({ path: '/'})刷新无效果问题
2020/01/16 Javascript
python元组操作实例解析
2014/09/23 Python
简单谈谈Python流程控制语句
2016/12/04 Python
对TensorFlow的assign赋值用法详解
2018/07/30 Python
对pandas写入读取h5文件的方法详解
2018/12/28 Python
python 读取dicom文件,生成info.txt和raw文件的方法
2019/01/24 Python
python爬虫基础教程:requests库(二)代码实例
2019/04/09 Python
python过滤中英文标点符号的实例代码
2019/07/15 Python
Pytorch十九种损失函数的使用详解
2020/04/29 Python
pytorch中 gpu与gpu、gpu与cpu 在load时相互转化操作
2020/05/25 Python
Python在centos7.6上安装python3.9的详细教程(默认python版本为2.7.5)
2020/10/15 Python
移动端适配 使px自动转换rem
2019/08/26 HTML / CSS
html5 canvas 简单画板实现代码
2012/01/05 HTML / CSS
优秀的个人求职信范文
2014/05/09 职场文书
2014四风问题对照检查材料范文
2014/09/15 职场文书
2014年个人工作总结模板
2014/12/15 职场文书
2015入党自传格式范文
2015/06/26 职场文书
2019公司借款合同范本2篇!
2019/07/24 职场文书
golang 实现两个结构体复制字段
2021/04/28 Golang