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
Dec 14 PHP
新浪微博API开发简介之用户授权(PHP基础篇)
Sep 25 PHP
PHP图片验证码制作实现分享(全)
May 10 PHP
PHPMailer邮件发送的实现代码
May 04 PHP
如何设置mysql允许外网访问
Jun 04 PHP
php实现约瑟夫问题的方法小结
Mar 23 PHP
PHP简单实现HTTP和HTTPS跨域共享session解决办法
May 27 PHP
PHP云打印类完整示例
Oct 15 PHP
PHP简单实现模拟登陆功能示例
Sep 15 PHP
CentOS7.0下安装PHP5.6.30服务的教程详解
Sep 29 PHP
PHP中的访问修饰符简单比较
Feb 02 PHP
phpStudy vscode 搭建debug调试的教程详解
Jul 28 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
全国FM电台频率大全 - 20 广西省
2020/03/11 无线电
golang实现php里的serialize()和unserialize()序列和反序列方法详解
2018/10/30 PHP
javascript开发技术大全 第4章 直接量与字符集
2011/07/03 Javascript
JAVASCRIPT函数作用域和提前声明 分享
2013/08/22 Javascript
js检验密码强度(低中高)附图
2014/06/05 Javascript
js/jquery判断浏览器的方法小结
2014/09/02 Javascript
用C/C++来实现 Node.js 的模块(二)
2014/09/24 Javascript
关于网页中的无缝滚动的js代码
2016/06/09 Javascript
JS制作图形验证码实现代码
2020/10/19 Javascript
利用jquery实现实时更新歌词的方法
2017/01/06 Javascript
Vue表单验证插件Vue Validator使用方法详解
2017/04/07 Javascript
Vue项目中Api的组织和返回数据处理的操作
2019/11/04 Javascript
微信小程序云开发获取文件夹下所有文件(推荐)
2019/11/14 Javascript
JavaScript实现串行请求的示例代码
2020/09/14 Javascript
[47:20]DAC2018 4.4 淘汰赛 Optic vs Mineski 第一场
2018/04/05 DOTA
使用python搭建Django应用程序步骤及版本冲突问题解决
2013/11/19 Python
在Python中关于中文编码问题的处理建议
2015/04/08 Python
python机器学习理论与实战(六)支持向量机
2018/01/19 Python
Python使用Pandas对csv文件进行数据处理的方法
2019/08/01 Python
python 命名规范知识点汇总
2020/02/14 Python
Python Selenium 设置元素等待的三种方式
2020/03/18 Python
keras 权重保存和权重载入方式
2020/05/21 Python
Python尾递归优化实现代码及原理详解
2020/10/09 Python
python设置中文界面实例方法
2020/10/27 Python
利用Bootstrap实现漂亮简洁的CSS3价格表实例源码
2017/03/02 HTML / CSS
HTML+CSS+JavaScript实现图片3D展览的示例代码
2020/10/12 HTML / CSS
蒂芙尼澳大利亚官方网站:Tiffany&Co. Australia
2017/08/27 全球购物
中医专业职业生涯规划书范文
2014/01/04 职场文书
村委会主任先进事迹
2014/01/15 职场文书
教师产假请假条
2014/04/10 职场文书
幼儿园教研活动总结
2014/04/30 职场文书
医学生求职自荐书
2014/06/12 职场文书
装修活动策划方案
2014/08/27 职场文书
反腐倡廉观后感
2015/06/08 职场文书
春节随笔
2015/08/15 职场文书
如何更改Win11声音输出设备?Win11声音输出设备四种更改方法
2022/04/08 数码科技