Yii中的relations方法
以Blog示例: 重点看注释
User类中的relations方法如下
- <span style="font-size:18px;background-color: rgb(255, 255, 255);"> public function relations()
- {
- return array(
- 'posts' => array(self::HAS_MANY, 'Post', 'author_id',
- 'order'=>'posts.update_time DESC',
- 'with'=>'comments:approved', // $user = User::model()->findByPk(1); 这里也查出了每篇post所带的comments
- //approved是comment的命名空间,可以在这里设置
- //'together'=>false, 设置这一项,关联查新将被分为几个SQL语句执行,和性能有关系
- ),
- 'postCount'=>array(
- self::STAT,'Post','author_id',
- 'condition'=>'status='.Post::STATUS_PUBLISHED,
- ),
- );
- }</span>
Post中的方法如下 :
- <span style="font-size:18px;background-color: rgb(255, 255, 255);">public function relations()
- {
- // NOTE: you may need to adjust the relation name and the related
- // class name for the relations automatically generated below.
- return array(
- 'author'=>array(self::BELONGS_TO,'User','author_id',
- //'select'=>'id,username,profile', // 关联查询的选项,如果不设置,则默认为*即整个关联记录
- ),
- 'comments'=>array(self::HAS_MANY,'Comment','post_id',
- 'condition'=>'comments.status='.Comment::STATUS_APPROVED,
- 'order'=>'comments.create_time DESC'),
- 'commentCount'=>array(
- self::STAT,'Comment','post_id',
- 'condition'=>'status='.Comment::STATUS_APPROVED
- ),
- );
- }
- </span>
Comment中的ralations方法如下:
- <span style="font-size:18px;background-color: rgb(255, 255, 255);">public function attributeLabels() //名字和现实标签的映射数组
- {
- return array(
- 'id' => 'Id',
- 'content' => 'Comment',
- 'status' => 'Status',
- 'create_time' => 'Create Time',
- 'author' => 'Name',
- 'email' => 'Email',
- 'url' => 'Website',
- 'post_id' => 'PostID', //对应的博客ID
- );
- }
- </span>
在控制器中写个方法测试一下结果:
- <span style="font-size:18px;background-color: rgb(255, 255, 255);"> public function actionRQ(){
- $post = Post::model()->find('id=:id',array(':id'=>7));
- echo $post->author->username;
- echo "<hr>";
- $posts = Post::model()->with('author','comments')->findAll(); //急切加载
- foreach($posts as $post){
- echo $post->id." |";
- foreach($post->comments as $comment){
- echo $comment->id.": ";
- echo $comment->content."<br>";
- }
- echo $post->author->username."<br>";
- }
- echo "<hr>";
- $user = User::model()->with('posts.comments')->findByPk(1);
- //$user = User::model()->findByPk(1); 这一句和上一句是一样的,因为在User的relations声明的posts也已经加上了关联查询:with=>'comments'
- foreach($user->posts as $post){ //嵌套急切加载
- echo $post->title." (";
- foreach($post->comments as $comment){
- echo $comment->id." : ";
- echo $comment->content."<br>";
- }
- echo ")".$post->tags."<br>";
- }
- echo "<hr>";
- $criteria = new CDbCriteria;
- //$criteria->select = "username";
- //$criteria->order
- //$criteria->limit
- //$criteria->condition
- //$criteria->params
- $criteria->with = array(
- 'posts.comments',
- );
- $users = User::model()->findAll($criteria);
- foreach($users as $user){
- echo $user->username.":<br>";
- //echo $user->password;
- foreach($user->posts as $post){ //嵌套急切加载
- echo $post->title." (";
- foreach($post->comments as $comment){
- echo $comment->id." : ";
- echo $comment->content."<br>";
- }
- echo ")".$post->tags."<br>";
- }
- }
- //动态关联查询,也就是在查询的时候覆盖relations中设置的关联的选项
- echo "<hr>";
- $user=User::model()->with(array(
- 'posts'=>array(
- 'order'=>'posts.update_time DESC',
- 'with'=>array('comments'=>array('order'=>'comments.id ASC')),
- //'together'=>false, //关联声明中设置together 选项为false 以便一些表被连接在单独的SQL语句中,分为几个SQL语句执行
- ),
- ))->findByPk(1);
- echo "demo 的posts数量为:".$user->postCount;
- echo "<br>";
- foreach($user->posts as $post){
- echo $post->id."(";
- echo $post->title."的评论数量是:".$post->commentCount."<br>";
- foreach($post->comments as $comment){
- echo $comment->id." | ";
- }
- echo ")";
- echo "<br>";
- }
- }</span>
- 原文来自 http://blog.csdn.net/littlebearwmx/article/details/8561018
Yii中的relations方法的更多相关文章
- C#中DataTable中的Compute方法使用收集
原文: C#中DataTable中的Compute方法使用收集 Compute函数的参数就两个:Expression,和Filter. Expresstion是计算表达式,关于Expression的详 ...
- Yii中的错误及异常处理
Yii中的错误及异常处理 Yii已经默认已经在CApplication上实现了异常和错误的接管,这是通过php的set_exception_handler, set_error_handler实现的. ...
- Yii中事件触发机制
控制器初始化中添加事件处理方法,在需要触发的地方直接触发 public function init() { parent::init(); // TODO: Change the autogenera ...
- 在yii中使用分页
yii中使用分页很方便,如下两种方法: 在控制器中: 1. $criteria = new CDbCriteria(); //new cdbcriteria数据库$criteria->id = ...
- yii中的自定义组件
yii中的自定义组件(组件就是一些自定义的公用类) 1.在项目目录中的protected/components/Xxxx.php 2.在Xxxx.php中定义一个类,类名必须与文件名相同 3.控制器中 ...
- YII中的表单挂件
利用助手(widget)在页面实现表单 控制器中 <?php class YiiFormController extends Controller { public function actio ...
- Javascript and AJAX with Yii(在yii 中使用 javascript 和ajax)
英文原文:http://www.yiiframework.com/wiki/394/javascript-and-ajax-with-yii /*** http://www.yiiframework. ...
- yii 中设置提示成功信息,错误提示信息,警告信息
方法一: <?php Yii::app()->user->setFlash(‘success’,”Data saved!”); 设置键值名为success的临时信息.在getFlas ...
- 解密yii中CModule::_components和CModule::_componentConfig
array CModule::_components 所有组件对象(CComponent的子类)将作为键值存在该数组中, 键名是定义该组件时使用的键名.例如: protected function r ...
随机推荐
- 周记5——随机撒花特效、动态修改伪元素样式、contenteditable属性、手机端调试利器VConsole、浏览器端debug调试
记录一些小零碎知识点,以便日后查看~ 1.随机撒花特效 教师节快到了,公司的产品提出一个需求:在IM(即时聊天)聊天界面弹出教师节的祝福“广告”,用户点击“发送祝福”按钮,聊天界面会随机撒花.这里的重 ...
- 从零开始制作H5人脸融合小游戏
去年的建军节,一个展示军装照的H5人脸融合游戏火遍朋友圈,带来很好的传播效果.最近欧冠决赛要来了,公司决定做一个寻找和你最像的欧冠球星的H5游戏,那么该怎么做呢?认真分析了一下,这个游戏其实用到的技术 ...
- jquery报表插件收藏 MARK
Highcharts http://www.hcharts.cn/ 统计报表插件 jquery ui官网 http://jqueryui.com/selectmenu/#custom_render
- CSS代码优化(转载)
要点1:css代码优化作用与意义 1.减少占用网页字节.在同等条件下缩短浏览器下载css代码时间,相当于加快网页打开速度:2.便于维护.简化和标准化css代码让css代码减少,便于日后维护:3.让自己 ...
- Java - 避免使用finalizer
Finalizers are unpredictable ,often dangerous ,and generally unnecessary. 在Java中,GC会自动回收不可达对象相关的空间,而 ...
- javascript bind在回调中精简匿名函数的用法
常规写法: Promise对象回调,匿名函数调用其他方法 更精简的写法: 注:这种写法的使用有两个严苛的限制. 1.回调的结果必须放在实际调用方法参数的最后一位: 2.回调函数中只调用其他一个方法.
- influxdb 的安装(centos)
安装命令: # for 64-bit systems wget http://s3.amazonaws.com/influxdb/influxdb-latest-1.x86_64.rpm sudo r ...
- Java Netty简介
Netty和Mina是Java世界非常知名的通讯框架.它们都出自同一个作者,Mina诞生略早,属于Apache基金会,而Netty开始在Jboss名下,后来出来自立门户netty.io(http:// ...
- Mybatis执行sql(insert、update、delete)返回值问题
数据库:Mysql 在使用mybatis的过程中对执行sql的返回值产生疑问,顺手记录一下. 结论: insert: 插入n条记录,返回影响行数n.(n>=1,n为0时实际为插入失败) up ...
- phpmyadmin登录报错crypt_random_string requires at least one symmetric cipher be loaded 解决方法
通过phpmyadmin登陆时提示以下错误: phpmyadmin crypt_random_string requires at least one symmetric cipher be load ...