Yii中的relations数据关联查询及统计功能用法详解
程序员文章站
2024-04-02 16:18:58
本文实例讲述了yii中的relations数据关联查询及统计功能用法。分享给大家供大家参考,具体如下:
关联查询,yii 也支持所谓的统计查询(或聚合查询)。 它指的是检...
本文实例讲述了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程序设计有所帮助。
推荐阅读
-
Yii中的relations数据关联查询及统计功能用法详解
-
Yii2中hasOne、hasMany及多对多关联查询的用法详解
-
Yii2中hasOne、hasMany及多对多关联查询的用法详解
-
Yii中的relations数据关联查询及统计功能用法详解
-
Yii - relations数据关联中的统计功能_PHP教程
-
Yii2中hasOne、hasMany及多对多关联查询的用法详解
-
Yii - relations数据关联中的统计功能_PHP教程
-
Yii2中hasOne、hasMany及多对多关联查询的用法示例(图)
-
Yii中的relations数据关联查询及统计功能用法详解
-
Yii2中hasOne、hasMany及多对多关联查询的用法示例(图)