Laravel使用MongoDB进行分组查询的示例-创新互联

这篇文章主要介绍Laravel使用MongoDB进行分组查询的示例,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

成都创新互联欢迎来电:028-86922220,为您提供成都网站建设网页设计及定制高端网站建设服务,成都创新互联网页制作领域十年,包括轻质隔墙板等多个行业拥有丰富的网站制作经验,选择成都创新互联,为企业锦上添花。

简介:在使用Laravel中如果要进行复杂的查询,那么通过模型中的函数来查询是不行的,所以本文主要记录如何通过aggregate来进行复杂的查询。

Laravel使用的mongodb库

composer require jenssegers/mongodb

分组查询

用户表中包含
city_id:城市ID
sex:性别,1男,2女
age:年龄
需要通过城市ID分组查询性别未男女的平均值,那么在laravel中实现如下,其他框架也大同小异

$cityId = 1;//城市ID
$count = UserModel::query()->raw(function ($collection) use ($cityId) {
    $aggregate = [];
    $aggregate[]['$match'] = [
        'city_id' => intval($city_id),//过滤城市
        'sex' => ['$in' => [1,2]],//过滤性别
    ];
    $aggregate[]['$group'] = [
        '_id' => '$sex',//更具性别进行分组
        'avg_age' => [
            '$avg' => '$age',//查询年龄平均值
        ]
    ];
    //这里还可以继续添加各种条件
    return $collection->aggregate($aggregate)->toArray();
});

以上是“Laravel使用MongoDB进行分组查询的示例”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!


文章名称:Laravel使用MongoDB进行分组查询的示例-创新互联
分享路径:http://bzwzjz.com/article/epcsh.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 温江网站设计 成都定制网站建设 重庆企业网站建设 高端网站设计推广 营销型网站建设 成都品牌网站设计 营销型网站建设 高端网站设计 网站设计制作报价 成都网站设计 重庆网站制作 品牌网站建设 成都网站制作 手机网站建设 广安网站设计 成都网站建设 成都网站制作 专业网站建设 网站建设 手机网站建设套餐 成都网站建设 商城网站建设