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 相关文章推荐
PHP5在Apache下的两种模式的安装
Sep 05 PHP
mysql 搜索之简单应用
Apr 27 PHP
php上传图片到指定位置路径保存到数据库的具体实现
Dec 30 PHP
重新认识php array_merge函数
Aug 31 PHP
php中常见的sql攻击正则表达式汇总
Nov 06 PHP
PHP 验证登陆类分享
Mar 13 PHP
PHP递归获取目录内所有文件的实现方法
Nov 01 PHP
PHP正则匹配日期和时间(时间戳转换)的实例代码
Dec 14 PHP
Python中使用django form表单验证的方法
Jan 16 PHP
对于Laravel 5.5核心架构的深入理解
Feb 22 PHP
PHP asXML()函数讲解
Feb 03 PHP
Yii框架模拟组件调用注入示例
Nov 11 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 curl模拟浏览器抓取网站信息
2013/10/28 PHP
php广告加载类用法实例
2014/09/23 PHP
PHP中imagick函数的中文解释
2015/01/21 PHP
php中session_id()函数详细介绍,会话id生成过程及session id长度
2015/09/23 PHP
PHP的PDO预定义常量讲解
2019/01/24 PHP
浅谈laravel框架与thinkPHP框架的区别
2019/10/23 PHP
下载网站打开页面后间隔多少时间才显示下载链接地址的代码
2010/04/25 Javascript
基于jQuery的message插件实现右下角弹出消息框
2011/01/11 Javascript
JavaScript中的私有/静态属性介绍
2012/07/26 Javascript
解决ExtJS在chrome或火狐中正常显示在ie中不显示的浏览器兼容问题
2013/01/11 Javascript
ExtJS DOM元素操作经验分享
2013/08/28 Javascript
jQuery动态改变图片显示大小(修改版)的实现思路及代码
2013/12/24 Javascript
删除节点的jquery代码
2014/01/13 Javascript
php利用curl获取远程图片实现方法
2015/10/26 Javascript
javascript中闭包(Closure)详解
2016/01/06 Javascript
jquery.form.js框架实现文件上传功能案例解析(springmvc)
2016/05/26 Javascript
jQuery实现查找最近父节点的方法
2016/06/23 Javascript
JavaScript实现数值自动增加动画
2017/12/28 Javascript
JS实现网站吸顶条
2020/01/08 Javascript
element跨分页操作选择详解
2020/06/29 Javascript
Vue this.$router.push(参数)实现页面跳转操作
2020/09/09 Javascript
python特性语法之遍历、公共方法、引用
2018/08/08 Python
python 检查是否为中文字符串的方法
2018/12/28 Python
详解python列表(list)的使用技巧及高级操作
2019/08/15 Python
Pytorch 搭建分类回归神经网络并用GPU进行加速的例子
2020/01/09 Python
Tensorflow Summary用法学习笔记
2020/01/10 Python
python tkinter GUI绘制,以及点击更新显示图片代码
2020/03/14 Python
Python为何不支持switch语句原理详解
2020/10/21 Python
用python-webdriver实现自动填表的示例代码
2021/01/13 Python
探索HTML5本地存储功能运用技巧
2016/03/02 HTML / CSS
Solid & Striped官网:美国泳装品牌
2019/06/19 全球购物
Hobbs官方网站:英国奢华女性时尚服装
2020/02/22 全球购物
简述安装Slackware Linux系统的过程
2012/05/08 面试题
2014年教师培训的自我评价
2014/01/03 职场文书
商场促销活动方案
2014/02/08 职场文书
幼儿园优秀教师事迹
2014/02/13 职场文书