Yii中的relations数据关联查询及统计功能用法详解

 更新时间:2016年07月14日 10:56:10   作者:dreamzml  
这篇文章主要介绍了Yii中的relations数据关联查询及统计功能用法,结合实例形式分析了关联查询命名空间及评论统计功能相关技巧,需要的朋友可以参考下

本文实例讲述了Yii中的relations数据关联查询及统计功能用法。分享给大家供大家参考,具体如下:

关联查询,Yii 也支持所谓的统计查询(或聚合查询)。 它指的是检索关联对象的聚合信息,例如每个 post 的评论的数量,每个产品的平均等级等。 统计查询只被 HAS_MANY(例如,一个 post 有很多评论) 或 MANY_MANY (例如,一个 post 属于很多分类和一个 category 有很多 post) 关联对象执行。

执行统计查询非常类似于之前描述的关联查询。我们首先需要在 CActiveRecord 的 relations() 方法中声明统计查询。

class Post extends CActiveRecord
{
  public function relations()
  {
    return array(
      'commentCount'=>array(self::STAT, 'Comment', 'post_id'),
      'categoryCount'=>array(self::STAT, 'Category', 'post_category(post_id,category_id)'),
    );
  }
}

关联查询命名空间

关联查询也可以和 命名空间一起执行。有两种形式。第一种形式,命名空间被应用到主模型。第二种形式,命名空间被应用到关联模型。

下面的代码展示了如何应用命名空间到主模型。

复制代码 代码如下:
$posts=Post::model()->published()->recently()->with('comments')->findAll();

这非常类似于非关联的查询。唯一的不同是我们在命名空间后使用了 with() 调用。 此查询应当返回最近发布的 post和它们的评论。

下面的代码展示了如何应用命名空间到关联模型。

复制代码 代码如下:
$posts=Post::model()->with('comments:recently:approved')->findAll();

上面的查询将返回所有的 post 及它们审核后的评论。注意 comments 指的是关联名字,而 recently 和 approved 指的是 在 Comment 模型类中声明的命名空间。关联名字和命名空间应当由冒号分隔。

命名空间也可以在 CActiveRecord::relations() 中声明的关联规则的 with 选项中指定。在下面的例子中, 若我们访问 $user->posts,它将返回此post 的所有审核后的评论。

class User extends CActiveRecord
{
  public function relations()
  {
    return array(
      'posts'=>array(self::HAS_MANY, 'Post', 'author_id', 'with'=>'comments:approved'),
    );
  }
}

更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

相关文章

  • CI框架出现mysql数据库连接资源无法释放的解决方法

    CI框架出现mysql数据库连接资源无法释放的解决方法

    这篇文章主要介绍了CI框架出现mysql数据库连接资源无法释放的解决方法,分析了CI框架出现连接超过最大值的原因与相应的解决方法,涉及CI框架相关配置技巧,需要的朋友可以参考下
    2016-05-05
  • Laravel 5.5 的自定义验证对象/类示例代码详解

    Laravel 5.5 的自定义验证对象/类示例代码详解

    Laravel 5.5 将提供一个全新的自定义验证规则的对象,以作为原来的 Validator::extend 方法的替代。接下来通过示例代码给大家介绍laravel 自定义验证对象和类,需要的朋友参考下吧
    2017-08-08
  • PHP dirname(__FILE__)原理及用法解析

    PHP dirname(__FILE__)原理及用法解析

    这篇文章主要介绍了PHP dirname(__FILE__)原理及用法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10
  • laravel5.4生成验证码的实例讲解

    laravel5.4生成验证码的实例讲解

    下面小编就为大家带来一篇laravel5.4生成验证码的实例讲解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • smarty简单分页的实现方法

    smarty简单分页的实现方法

    这篇文章主要介绍了smarty简单分页的实现方法,以一个具体的实例讲述了smarty分页的完整实现过程,需要的朋友可以参考下
    2014-10-10
  • PHP的switch判断语句的“高级”用法详解

    PHP的switch判断语句的“高级”用法详解

    这篇文章主要介绍了PHP的switch判断语句的“高级”用法详解,其实本文讲解的还是它的基础用法,需要的朋友可以参考下
    2014-10-10
  • laravel框架使用FormRequest进行表单验证,验证异常返回JSON操作示例

    laravel框架使用FormRequest进行表单验证,验证异常返回JSON操作示例

    这篇文章主要介绍了laravel框架使用FormRequest进行表单验证,验证异常返回JSON操作,涉及laravel表单请求类的创建、使用及异常处理相关操作技巧,需要的朋友可以参考下
    2020-02-02
  • PHP加密解密类实例代码

    PHP加密解密类实例代码

    这篇文章主要介绍了PHP加密解密类实例代码的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-07-07
  • 详解PHP合并多个PDF文件的方法

    详解PHP合并多个PDF文件的方法

    这篇文章主要介绍了PHP合并多个PDF文件的示例代码,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07
  • 使用laravel根据用户类型来显示或隐藏字段

    使用laravel根据用户类型来显示或隐藏字段

    今天小编就为大家分享一篇使用laravel根据用户类型来显示或隐藏字段,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-10-10

最新评论