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 相关文章推荐
在JavaScript中调用php程序
Mar 09 PHP
apache+php+mysql安装配置方法小结
Aug 01 PHP
新手菜鸟必读:session与cookie的区别
Aug 22 PHP
php共享内存段示例分享
Jan 20 PHP
从零开始学YII2框架(三)扩展插件yii2-gird
Aug 20 PHP
MacOS 安装 PHP的图片裁剪扩展Tclip
Mar 25 PHP
php使用MySQL保存session会话的方法
Jun 18 PHP
php实现对象克隆的方法
Jun 20 PHP
学习php设计模式 php实现享元模式(flyweight)
Dec 07 PHP
PHP微信开发之有道翻译
Jun 23 PHP
PHP生成各种随机验证码的方法总结【附demo源码】
Jun 05 PHP
PHP使用非对称加密算法RSA
Apr 21 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
ThinkPHP惯例配置文件详解
2014/07/14 PHP
php禁止直接从浏览器输入地址访问.php文件的方法
2014/11/04 PHP
浅谈php优化需要注意的地方
2014/11/27 PHP
PHP magento后台无法登录问题解决方法
2016/11/24 PHP
javascript入门·对象属性方法大总结
2007/10/01 Javascript
Safari5中alert的无限循环BUG
2011/04/07 Javascript
uploadify 3.0 详细使用说明
2012/06/18 Javascript
JQuery中DOM事件绑定用法详解
2015/06/13 Javascript
理解js对象继承的N种模式
2016/01/25 Javascript
Windows 系统下设置Nodejs NPM全局路径
2016/04/26 NodeJs
Vue.js教程之计算属性
2016/11/11 Javascript
简单实现Vue的observer和watcher
2016/12/21 Javascript
详解vue与后端数据交互(ajax):vue-resource
2017/03/16 Javascript
vue.js源代码core scedule.js学习笔记
2017/07/03 Javascript
bootstrap模态框嵌套、tabindex属性、去除阴影的示例代码
2017/10/17 Javascript
Vue 获取数组键名的方法
2018/06/21 Javascript
node.js使用zlib模块进行数据压缩和解压操作示例
2020/02/12 Javascript
vue实现在线学生录入系统
2020/05/30 Javascript
vue-cli3 引入 font-awesome的操作
2020/08/11 Javascript
基于python编写的微博应用
2014/10/17 Python
python 调用HBase的简单实例
2016/12/18 Python
Python中str.join()简单用法示例
2018/03/20 Python
python实现抖音点赞功能
2019/04/07 Python
pycharm中import呈现灰色原因的解决方法
2020/03/04 Python
美国知名户外用品畅销中心:Sierra Trading Post
2016/07/19 全球购物
巴西体育用品商店:Lojão dos Esportes
2018/07/21 全球购物
How TDD works
2012/09/30 面试题
中专生求职自荐信范文
2013/12/22 职场文书
员工年终自我评价
2014/09/14 职场文书
2014年残联工作总结
2014/11/21 职场文书
优秀班主任主要事迹材料
2014/12/16 职场文书
电影地道战观后感
2015/06/04 职场文书
绿里奇迹观后感
2015/06/15 职场文书
董事长新年致辞
2015/07/29 职场文书
2019中秋节祝福语大全,提前收藏啦
2019/09/10 职场文书
Django对接elasticsearch实现全文检索的示例代码
2021/08/02 Python