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 相关文章推荐
在windows iis5下安装php4.0+mysql之我见
Oct 09 PHP
浅析PHP递归函数返回值使用方法
Feb 18 PHP
PHP根据传来的16进制颜色代码自动改变背景颜色
Jun 13 PHP
PHP获取时间排除周六、周日的两个方法
Jun 30 PHP
php中unserialize返回false的解决方法
Sep 22 PHP
PHP定时任务延缓执行的实现
Oct 08 PHP
制作安全性高的PHP网站的几个实用要点
Dec 30 PHP
PHP实现RTX发送消息提醒的实例代码
Jan 03 PHP
PHP中常用的魔术方法
Apr 28 PHP
php获取用户真实IP和防刷机制的实例代码
Nov 28 PHP
浅析PHP7 的垃圾回收机制
Sep 06 PHP
php+layui数据表格实现数据分页渲染代码
Oct 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按行读取文件时删除换行符的3种方法
2014/05/04 PHP
php的mail函数发送UTF-8编码中文邮件时标题乱码的解决办法
2015/10/20 PHP
php实现微信公众平台发红包功能
2018/06/14 PHP
PHP中的访问修饰符简单比较
2019/02/02 PHP
PHP递归统计系统中代码行数
2019/09/19 PHP
利用jQuery的$.event.fix函数统一浏览器event事件处理
2009/12/21 Javascript
基于jquery的使ListNav兼容中文首字拼音排序的实现代码
2011/07/10 Javascript
基于javascipt-dom编程 table对象的使用
2013/04/22 Javascript
jQuery图片滚动图片的效果(另类实现)
2013/06/02 Javascript
JS动态改变表格边框宽度的方法
2015/03/31 Javascript
基于jQuery的Web上传插件Uploadify使用示例
2016/05/19 Javascript
AngularJs Understanding the Controller Component
2016/09/02 Javascript
数组Array的一些方法(总结)
2017/02/17 Javascript
jquery.uploadifive插件怎么解决上传限制图片或文件大小问题
2017/05/08 jQuery
Vue-router 切换组件页面时进入进出动画方法
2018/09/01 Javascript
在nodejs中创建child process的方法
2021/01/26 NodeJs
使用Python将数组的元素导出到变量中(unpacking)
2016/10/27 Python
Python3编程实现获取阿里云ECS实例及监控的方法
2017/08/18 Python
用python建立两个Y轴的XY曲线图方法
2019/07/08 Python
django如何自己创建一个中间件
2019/07/24 Python
在keras下实现多个模型的融合方式
2020/05/23 Python
使用Filters滤镜弥补CSS3的跨浏览器问题以及兼容低版本IE
2013/01/23 HTML / CSS
蒂芙尼澳大利亚官方网站:Tiffany&Co. Australia
2017/08/27 全球购物
俄罗斯便宜的在线服装商店:GroupPrice
2020/04/10 全球购物
MIKI HOUSE美国官方网上商店:日本领先的婴儿和儿童高级时装品牌
2020/06/21 全球购物
几道数据库的面试题或笔试题
2014/05/31 面试题
行政部主管岗位职责
2013/12/28 职场文书
超级搞笑检讨书
2014/01/15 职场文书
党代会心得体会
2014/09/04 职场文书
教育局党的群众路线教育实践活动整改方案
2014/09/20 职场文书
2015社区六五普法工作总结
2015/04/21 职场文书
导游词之湖北武当山
2019/09/23 职场文书
七年级作文之英语老师
2019/10/28 职场文书
超级详细实用的pycharm常用快捷键
2021/05/12 Python
【海涛dota解说】一房久违的影魔魂守二连发
2022/04/01 DOTA
Sql Server 行数据的某列值想作为字段列显示的方法
2022/04/20 SQL Server