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巧获服务器端信息
Dec 06 PHP
PHP开发过程中常用函数收藏
Dec 14 PHP
在PHP中使用反射技术的架构插件使用说明
May 18 PHP
PHP 5.3 下载时 VC9、VC6、Thread Safe、Non Thread Safe的区别分析
Mar 28 PHP
PHP spl_autoload_register实现自动加载研究
Dec 06 PHP
zf框架db类的分页示例分享
Mar 14 PHP
PHP实现格式化文件数据大小显示的方法
Jan 03 PHP
PHP常用工具类大全附全部代码下载
Dec 07 PHP
PHP获取用户客户端真实IP的解决方案
Oct 10 PHP
深入讲解PHP的对象注入(Object Injection)
Mar 01 PHP
PHP实现SMTP邮件的发送实例
Sep 27 PHP
php7 错误处理机制修改实例分析
May 25 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(1)
2006/10/09 PHP
查找php配置文件php.ini所在路径的二种方法
2014/05/26 PHP
php实现批量修改文件名称的方法
2016/07/23 PHP
php 获取文件行数的方法总结
2016/10/11 PHP
Yii2框架redis基本应用示例
2018/07/13 PHP
PHP扩展mcrypt实现的AES加密功能示例
2019/01/29 PHP
Javascript显示和隐藏ul列表的方法
2015/07/15 Javascript
javascript常用的方法整理
2015/08/20 Javascript
JS实现自动切换文字的导航效果代码
2015/08/27 Javascript
实例代码讲解jquery easyui动态tab页
2015/11/17 Javascript
JS实现的在线调色板实例(附demo源码下载)
2016/03/01 Javascript
bootstrap快速制作后台界面
2016/12/05 Javascript
jquery实现(textarea)placeholder自动换行
2016/12/22 Javascript
解析jquery easyui tree异步加载子节点问题
2017/03/08 Javascript
浅谈express.js框架中间件(middleware)
2019/04/07 Javascript
在python的类中动态添加属性与生成对象
2016/09/17 Python
python sys.argv[]用法实例详解
2018/05/25 Python
python使用xlsxwriter实现有向无环图到Excel的转换
2018/12/12 Python
Python 获取div标签中的文字实例
2018/12/20 Python
Python实现滑动平均(Moving Average)的例子
2019/08/24 Python
Python shutil模块用法实例分析
2019/10/02 Python
python+Django+pycharm+mysql 搭建首个web项目详解
2019/11/29 Python
分享30个新鲜的CSS3打造的精美绚丽效果(附演示下载)
2012/12/28 HTML / CSS
轻松掌握CSS3中的字体大小单位rem的使用方法
2016/05/24 HTML / CSS
将SVG图引入到HTML页面的实现
2019/09/20 HTML / CSS
DAWGS鞋官方网站:鞋,凉鞋,靴子
2016/10/04 全球购物
JSF面试题:Jsf中的核心类用那些?有什么作用?LiftCycle六大生命周期是什么?
2014/07/17 面试题
威盛公司软件C++工程师笔试题面试题
2012/07/16 面试题
英语教师岗位职责
2014/03/16 职场文书
横幅标语大全
2014/06/17 职场文书
2014卖家双十一活动策划书
2014/09/29 职场文书
大学生党员批评与自我批评范文
2014/10/14 职场文书
小学教研工作总结2015
2015/05/13 职场文书
Python中的np.argmin()和np.argmax()函数用法
2021/06/02 Python
win10键盘驱动怎么修复?Win10键盘驱动修复小技巧
2022/04/06 数码科技
基于PyQt5制作一个群发邮件工具
2022/04/08 Python