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简单封装了一些常用JS操作
Feb 25 PHP
FCKeditor添加自定义按钮
Mar 27 PHP
PHP基础学习小结
Apr 17 PHP
探讨Smarty中如何获取数组的长度以及smarty调用php函数的详解
Jun 20 PHP
php实现源代码加密的方法
Jul 11 PHP
详解WordPress中提醒安装插件以及隐藏插件的功能实现
Dec 25 PHP
php外部执行命令函数用法小结
Oct 11 PHP
PHP之将POST数据转化为字符串的实现代码
Nov 03 PHP
php获取'/'传参的值简单方法
Jul 13 PHP
PHP自定义递归函数实现数组转JSON功能【支持GBK编码】
Jul 17 PHP
PHP使用redis位图bitMap 实现签到功能
Oct 08 PHP
Thinkphp 框架扩展之行为扩展原理与实现方法分析
Apr 23 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
从Web查询数据库之PHP与MySQL篇
2009/09/25 PHP
解析php时间戳与日期的转换
2013/06/06 PHP
深入php多态的实现详解
2013/06/09 PHP
PHP中的插件机制原理和实例
2014/07/08 PHP
PHP生成唯一订单号的方法汇总
2015/04/16 PHP
php超快高效率统计大文件行数
2015/07/05 PHP
设定php简写功能的方法
2019/11/28 PHP
JavaScript window.location对象
2014/11/14 Javascript
深入理解JavaScript系列(31):设计模式之代理模式详解
2015/03/03 Javascript
常用javascript表单验证汇总
2020/07/20 Javascript
JS和jQuery使用submit方法无法提交表单的原因分析及解决办法
2016/05/17 Javascript
js获取时间函数及扩展函数的方法
2016/10/30 Javascript
js实现将json数组显示前台table中
2017/01/10 Javascript
JS异步加载的三种实现方式
2017/03/16 Javascript
vue.js过滤器+ajax实现事件监听及后台php数据交互实例
2018/05/22 Javascript
Rollup处理并打包JS文件项目实例代码
2018/05/31 Javascript
Vue.js中的高级面试题及答案
2020/01/13 Javascript
Vue.js实现立体计算器
2020/02/22 Javascript
vue中的过滤器及其时间格式化问题
2020/04/09 Javascript
vue下载二进制流图片操作
2020/10/26 Javascript
举例讲解Django中数据模型访问外键值的方法
2015/07/21 Python
详解Python函数作用域的LEGB顺序
2016/05/14 Python
Python 爬虫学习笔记之多线程爬虫
2016/09/21 Python
关于Django显示时间你应该知道的一些问题
2017/12/25 Python
Matplotlib 生成不同大小的subplots实例
2018/05/25 Python
python3实现基于用户的协同过滤
2018/05/31 Python
python中random.randint和random.randrange的区别详解
2020/09/20 Python
HTML5拖放功能_动力节点Java学院整理
2017/07/13 HTML / CSS
美国最受欢迎的童装品牌之一:The Children’s Place
2016/07/23 全球购物
清洁工表扬信
2014/01/08 职场文书
高级销售求职信
2014/02/21 职场文书
事业单位分类改革实施方案
2014/03/21 职场文书
毕业生如何写自荐信
2014/03/26 职场文书
绿色环保标语
2014/06/12 职场文书
个人三严三实对照检查材料思想汇报
2014/09/22 职场文书
数学备课组工作总结
2015/08/12 职场文书