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开发GUI
Oct 09 PHP
Access数据库导入Mysql的方法之一
Oct 09 PHP
PHP5.2中date()函数显示时间与北京时间相差8小时的解决办法
May 28 PHP
php下正则来匹配dede模板标签的代码
Aug 21 PHP
fleaphp crud操作之findByField函数的使用方法
Apr 23 PHP
PHP高级对象构建 工厂模式的使用
Feb 05 PHP
PHP实现AES256加密算法实例
Sep 22 PHP
PHP中使用array函数新建一个数组
Nov 19 PHP
php使用curl代理实现抓取数据的方法
Feb 03 PHP
PHP中快速生成随机密码的几种方式
Apr 17 PHP
如何直接访问php实例对象中的private属性详解
Oct 12 PHP
PHP中cookie知识点学习
May 06 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之字符串变相相减的代码
2007/03/19 PHP
thinkphp 多表 事务详解
2013/06/17 PHP
PHP递归遍历指定目录的文件并统计文件数量的方法
2015/03/24 PHP
PHP CURL post数据报错 failed creating formpost data
2016/10/16 PHP
JavaScript For Beginners(转载)
2007/01/05 Javascript
新鲜出炉的js tips提示效果
2011/04/03 Javascript
javascript 弹出窗口中是否显示地址栏的实现代码
2011/04/14 Javascript
Egret引擎开发指南之发布项目
2014/09/03 Javascript
JavaScript计时器示例分析
2015/02/05 Javascript
jQuery中slideUp 和 slideDown 的点击事件
2015/02/26 Javascript
JS中用三种方式实现导航菜单中的二级下拉菜单
2016/10/31 Javascript
javascript获取以及设置光标位置
2017/02/16 Javascript
JavaScript实现的冒泡排序法及统计相邻数交换次数示例
2017/04/26 Javascript
Angular+Node生成随机数的方法
2017/06/16 Javascript
浅谈关于.vue文件中style的scoped属性
2017/08/19 Javascript
vue 中filter的多种用法
2018/04/26 Javascript
Vue三层嵌套路由的示例代码
2018/05/05 Javascript
解决vue中虚拟dom,无法实时更新的问题
2018/09/15 Javascript
js实现点赞效果
2020/03/16 Javascript
vue同个按钮控制展开和折叠同个事件操作
2020/07/29 Javascript
vue npm install 安装某个指定的版本操作
2020/08/11 Javascript
vue 图片裁剪上传组件的实现
2020/11/12 Javascript
详解微信小程序轨迹回放实现及遇到的坑
2021/02/02 Javascript
Python用GET方法上传文件
2015/03/10 Python
深入解析Python中的WSGI接口
2015/05/11 Python
Python元组及文件核心对象类型详解
2018/02/11 Python
python 返回一个列表中第二大的数方法
2019/07/09 Python
学习Python爬虫的几点建议
2020/08/05 Python
详解h5页面在不同ios设备上的问题总结
2019/03/01 HTML / CSS
科沃斯机器人官网商城:Ecovacs
2016/08/29 全球购物
Debenhams爱尔兰:英国知名的百货公司
2017/01/02 全球购物
丝芙兰意大利官方网站:Sephora.it
2019/12/13 全球购物
音乐系毕业生自荐信
2013/10/27 职场文书
安全宣传标语
2014/06/10 职场文书
2014年自愿离婚协议书
2014/10/10 职场文书
习总书记三严三实学习心得体会
2014/10/13 职场文书