Yii框架关联查询with用法分析


Posted in PHP onDecember 02, 2014

本文实例分析了Yii框架关联查询with用法。分享给大家供大家参考。具体方法如下:

Yii框架关联查询与mysql中的关联查询会有什么区别呢?这里小编就与各位来一起来看看吧。

Yii的关联查询确实是一个方便的东西,网上的资料也很多,但是大部分都是Ctrl+c,Ctrl+v,有些东西一直没有人出来详细的写篇文章说明一下,在参考了网上很多资源以后,加上自己的的一些理解,写下了这篇文章,给广大初学者朋友们提供一点个人见解。

YII 支持四种类型的关系:

BELONGS_TO(属于): 如果表 A 和 B 之间的关系是一对多,则 表 B 属于 表 A (例如 Post 属于 User);
HAS_MANY(有多个): 如果表 A 和 B 之间的关系是一对多,则 A 有多个 B (例如 User 有多个 Post);
HAS_ONE(有一个): 这是 HAS_MANY 的一个特例,A 最多有一个 B (例如 User 最多有一个 Profile);
MANY_MANY: 这个对应于数据库中的 多对多 关系。 由于多数 DBMS 不直接支持 多对多 关系,因此需要有一个关联表将 多对多 关系分割为 一对多 关系。
 
菜鸟们看到这个真的能明白吗?

初学的时候,个人表示头晕至极,经过反复的测试,我给大家非常直白的解释一下。
现有用户表user和博客表blog,博客是属于某个用户的,而用户会发表多篇博客。
BELONGS_TO:
controller

$blogs = $blog_model->with('b_user')->find();

model 这里的model指的是blog_model
'b_user'=>array(self::BELONGS_TO, 'user', 'author')

适用范围,查找博客的时候需要把博客的作者也查出来。
b_user中第二个参数:子表的表名,第三个参数,主表中用于存子表主键的字段(blog表中用于存user表主键的字段)。
 
HAS_ONE:
controller
$user_blog = $user_model->with('u_blog')->find();

model 这里的的model指的是user_model
'u_blog'=>array(self::HAS_ONE, 'blog', 'author')

测试一下,不仅仅查出了作者的信息,而且还查出了一篇该作者的博客。
u_blog中的第二个参数:子表表名,第三个参数,子表中用于存主表主键的字段(blog表中用于存user表主键的字段)。
 
HAS_MANY:
controller
$user_blogs = $user_model->with('u_blogs')->find();

model 这里的的model指的是user_model
'u_blogs'=>array(self::HAS_MANY, 'blog', 'author')

测试一下,不仅仅查出了作者的信息,也不仅仅查出了一篇该作者的博客,而且还查出了该作者其它的博客。
u_blogs中的第二个参数:子表表名,第三个参数,子表中用于存主表主键的字段(blog表中用于存user表主键的字段)。
 
MANY_TO_MANY:
这个东西啊,我还没用过,貌似基本上也不会用到,待我测一下,再来续上。。。
 
至此,Yii with的最最基本用法说的差不多了,但是你就没有啥疑问吗?
如何指定要查询的子表字段?
HAS_MANY中查出了该用户的所有文章,如果我只想要查5篇呢?
……等你来提问。
那么,废话不多说,解决第一个问题
'u_blogs'=>array(self::HAS_MANY, 'blog', 'author','select'=>'gid,title,content')

这样试试?
第二个问题
'u_blogs'=>array(self::HAS_MANY, 'blog', 'author','select'=>'gid,title,content','condition'=>'u_blogs.gid=2')

搞定!
 
相信看过这些非常小白的讲解后应该恍然大悟了吧。此所谓万事开头难啊,剩下的东西相信你一看就懂了~~~
 
以下内容来自Yii手册:
 
延迟加载时有一定的关系,下列选项可用:
'group': string, GROUP BY子句。 默认值为空。 注意,列引用需要加入'relationName'前缀 。(例如: relationName.age)。此选项仅适用于HAS_MANY 和 MANY_MANY 关系。
'having': string, HAVING子句。 默认值为空。 注意,列引用需要加入'relationName'前缀 。(例如: relationName.age)。此选项仅适用于HAS_MANY 和 MANY_MANY 关系。
'limit': 数据行的limit选择。 这个选项不能应用到BELONGS_TO。
'offset': 数据行的偏移量。 这个选项不能应用到BELONGS_TO。
'through': 获取相关的数据时将用作桥的模型的关系的名称。可以设置仅为 HAS_ONE 和 HAS_MANY。此选项自版本 1.1.7 可用。

以下是一个例子,为 'Post' 活动记录类相关对象的一个示例:

return array(

    'author'=>array(self::BELONGS_TO, 'User', 'author_id'),

    'comments'=>array(self::HAS_MANY, 'Comment', 'post_id', 'with'=>'author', 'order'=>'create_time DESC'),

    'tags'=>array(self::MANY_MANY, 'Tag', 'post_tag(post_id, tag_id)', 'order'=>'name'),

);

希望本文所述对大家的yii框架程序设计有所帮助。

PHP 相关文章推荐
php实现的九九乘法口诀表简洁版
Jul 28 PHP
PHP动态页生成静态页的3种常用方法
Nov 13 PHP
php页面函数设置超时限制的方法
Dec 01 PHP
Linux中为php配置伪静态
Dec 17 PHP
php简单定时执行任务的实现方法
Feb 23 PHP
PHP中foreach()用法汇总
Jul 02 PHP
php生成数字字母的验证码图片
Jul 14 PHP
php实现的http请求封装示例
Nov 08 PHP
php app支付宝回调(异步通知)详解
Jul 25 PHP
PDO::_construct讲解
Jan 27 PHP
在Laravel5中正确设置文件权限的方法
May 22 PHP
Laravel 微信小程序后端搭建步骤详解
Nov 26 PHP
phpstorm配置Xdebug进行调试PHP教程
Dec 01 #PHP
页面利用渐进式JPEG来提升用户体验度
Dec 01 #PHP
php页面函数设置超时限制的方法
Dec 01 #PHP
PHP实现抓取HTTPS内容
Dec 01 #PHP
php设置静态内容缓存时间的方法
Dec 01 #PHP
thinkphp实现发送邮件密码找回功能实例
Dec 01 #PHP
PHP清除字符串中所有无用标签的方法
Dec 01 #PHP
You might like
PHP人民币金额数字转中文大写的函数代码
2013/02/27 PHP
PHP模板引擎Smarty内建函数foreach,foreachelse用法分析
2016/04/11 PHP
PHP7+Nginx的配置与安装教程详解
2016/05/10 PHP
PHP写的简单数字验证码实例
2017/05/23 PHP
PHP创建单例后台进程的方法示例
2017/05/23 PHP
php的扩展写法总结
2019/05/14 PHP
更优雅的事件触发兼容
2011/10/24 Javascript
基于jquery库的tab新形式使用
2012/11/16 Javascript
Firefox中使用outerHTML的2种解决方法
2014/06/07 Javascript
JS遍历页面所有对象属性及实现方法
2016/08/01 Javascript
完美解决IE9浏览器出现的对象未定义问题
2016/09/29 Javascript
微信小程序遇到修改数据后页面不渲染的问题解决
2017/03/09 Javascript
详解JavaScript中的数组合并方法和对象合并方法
2018/05/11 Javascript
详解vue-router传参的两种方式
2018/09/10 Javascript
JavaScript this绑定过程深入详解
2018/12/07 Javascript
vue中获取滚动table的可视页面宽度调整表头与列对齐(每列宽度不都相同)
2019/08/17 Javascript
js单线程的本质 Event Loop解析
2019/10/29 Javascript
详解在Python的Django框架中创建模板库的方法
2015/07/20 Python
Python的Scrapy爬虫框架简单学习笔记
2016/01/20 Python
python类:class创建、数据方法属性及访问控制详解
2016/07/25 Python
Python使用正则表达式过滤或替换HTML标签的方法详解
2017/09/25 Python
Python3简单实例计算同花的概率代码
2017/12/06 Python
python 计算两个列表的相关系数的实现
2019/08/29 Python
python3 webp转gif格式的实现示例
2019/12/10 Python
tensorflow 自定义损失函数示例代码
2020/02/05 Python
python通用读取vcf文件的类(复制粘贴即可用)
2020/02/29 Python
Python并发请求下限制QPS(每秒查询率)的实现代码
2020/06/05 Python
python求numpy中array按列非零元素的平均值案例
2020/06/08 Python
python实现无边框进度条的实例代码
2020/12/30 Python
Gap英国官网:Gap UK
2018/07/18 全球购物
计算机应用专业应届毕业生中文求职信范文
2013/11/29 职场文书
我的动漫时代的创业计划书范文
2014/01/27 职场文书
奥林匹克的口号
2014/06/13 职场文书
政府领导干部个人对照检查材料思想汇报
2014/09/24 职场文书
少年犯观后感
2015/06/11 职场文书
vue本地构建热更新卡顿的问题“75 advanced module optimization”完美解决方案
2022/08/05 Vue.js