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 相关文章推荐
ASP知识讲座四
Oct 09 PHP
?算你??的 PHP 程式大小
Dec 06 PHP
php采集速度探究总结(原创)
Apr 18 PHP
用php获取本周,上周,本月,上月,本季度日期的代码
Aug 05 PHP
PHP数据库链接类(PDO+Access)实例分享
Dec 05 PHP
php 使用GD库为页面增加水印示例代码
Mar 24 PHP
用php来限制每个ip每天浏览页面数量的实现思路
Feb 24 PHP
PHP会话处理的10个函数
Aug 11 PHP
PHP Web木马扫描器代码分享
Sep 06 PHP
Ajax PHP JavaScript MySQL实现简易无刷新在线聊天室
Aug 17 PHP
PHP设计模式之装饰器模式实例详解
Feb 07 PHP
Ajax+Jpgraph实现的动态折线图功能示例
Feb 11 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网站备份程序代码分享
2011/06/10 PHP
部署PHP项目应该注意的几点事项分享
2013/12/20 PHP
一个比较不错的PHP日历类分享
2014/11/18 PHP
js中replace的用法总结
2013/12/27 Javascript
修复bash漏洞的shell脚本分享
2014/12/31 Javascript
简化版手机端照片预览组件
2015/04/13 Javascript
jQuery实现鼠标滑过点击事件音效试听
2015/08/31 Javascript
jquery实现仿Flash的横向滑动菜单效果代码
2015/09/17 Javascript
JavaScript生成二维码图片小结
2015/12/27 Javascript
canvas实现动态小球重叠效果
2017/02/06 Javascript
jquery 校验中国身份证号码实例详解
2017/04/11 jQuery
mockjs,json-server一起搭建前端通用的数据模拟框架教程
2017/12/18 Javascript
解决vue2.0动态绑定图片src属性值初始化时报错的问题
2018/03/14 Javascript
从零开始搭建webpack+react开发环境的详细步骤
2018/05/18 Javascript
node学习笔记之读写文件与开启第一个web服务器操作示例
2019/05/29 Javascript
微信小程序引入Vant组件库过程解析
2019/08/06 Javascript
React学习之受控组件与数据共享实例分析
2020/01/06 Javascript
vue+element 实现商城主题开发的示例代码
2020/03/26 Javascript
Vue 封装防刷新考试倒计时组件的实现
2020/06/05 Javascript
vue实现购物车的小练习
2020/12/21 Vue.js
[01:10:02]IG vs Winstrike 2018国际邀请赛小组赛BO2 第一场 8.19
2018/08/21 DOTA
在Windows服务器下用Apache和mod_wsgi配置Python应用的教程
2015/05/06 Python
详解Python中open()函数指定文件打开方式的用法
2016/06/04 Python
Python随机生成手机号、数字的方法详解
2017/07/21 Python
python基础_文件操作实现全文或单行替换的方法
2017/09/04 Python
Python反爬虫技术之防止IP地址被封杀的讲解
2019/01/09 Python
使用Python+wxpy 找出微信里把你删除的好友实例
2019/02/21 Python
PyQt5实现QLineEdit添加clicked信号的方法
2019/06/25 Python
Python使用Opencv实现图像特征检测与匹配的方法
2019/10/30 Python
Python 过滤错误log并导出的实例
2019/12/26 Python
利用python中的matplotlib打印混淆矩阵实例
2020/06/16 Python
HTML5学习笔记之html5与传统html区别
2016/01/06 HTML / CSS
感恩节寄语2015
2015/03/24 职场文书
2016公司年会通知范文
2015/04/25 职场文书
python中%格式表达式实例用法
2021/06/18 Python
vmware虚拟机打不开vmx文件怎么办 ?vmware虚拟机vmx文件打开方法
2022/04/08 数码科技