热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

mongodbgroupphp操作

紧接着上篇来,这篇主要讲,mongodb的group功能,做的还是挺强大的,相当对于find(),skip(),distinct()等,用法比较复杂。测试数据db.fruit.find();{_id:1,category:fruit,name:apple}{_id:2,category:fruit,name:

紧接着上篇来,这篇主要讲,mongodb的group功能,做的还是挺强大的,相当对于find(),skip(),distinct()等,用法比较复杂。 测试数据 db.fruit.find();{ "_id" : 1, "category" : "fruit", "name" : "apple" }{ "_id" : 2, "category" : "fruit", "name" :

紧接着上篇来,这篇主要讲,mongodb的group功能,做的还是挺强大的,相当对于find(),skip(),distinct()等,用法比较复杂。

测试数据

> db.fruit.find();
{ "_id" : 1, "category" : "fruit", "name" : "apple" }
{ "_id" : 2, "category" : "fruit", "name" : "peach" }
{ "_id" : 3, "category" : "fruit", "name" : "banana" }
{ "_id" : 4, "category" : "veggie", "name" : "corn" }
{ "_id" : 5, "category" : "veggie", "name" : "broccoli" }

1,根据category分组

> db.fruit.group(
?????? {
???????? key: { category: 1},
???????? reduce: function(obj, prev) {
???????????????????? prev.items.push(obj.name);
???????????????? },
???????? initial: { items : [] }
?????? }
??? );
[
??????? {
??????????????? "category" : "fruit",
??????????????? "items" : [
??????????????????????? "apple",
??????????????????????? "peach",
??????????????????????? "banana"
??????????????? ]
??????? },
??????? {
??????????????? "category" : "veggie",
??????????????? "items" : [
??????????????????????? "corn",
??????????????????????? "broccoli"
??????????????? ]
??????? }
]

php代码如下

$keys = array("category" => 1);
$initial = array("items" => array());
$reduce = "function (obj, prev) { prev.items.push(obj.name); }";
$g = $collection->group($keys, $initial, $reduce);
print_r($g);?? //结果如下。
Array
(
??? [retval] => Array
??????? (
??????????? [0] => Array
??????????????? (
??????????????????? [category] => fruit
??????????????????? [items] => Array
??????????????????????? (
??????????????????????????? [0] => apple
??????????????????????????? [1] => peach
??????????????????????????? [2] => banana
??????????????????????? )
??????????????? )
??????????? [1] => Array
??????????????? (
??????????????????? [category] => veggie
??????????????????? [items] => Array
??????????????????????? (
??????????????????????????? [0] => corn
??????????????????????????? [1] => broccoli
??????????????????????? )
??????????????? )
??????? )
??? [count] => 5
??? [keys] => 2
??? [ok] => 1
)

2,根据category来分组,并统计count

> db.fruit.group(
?????????? {
???????????? key: { category: 1},
???????????? cond: { _id: { $gt: 2 } },
???????????? reduce: function(obj, prev) {
??????????????? prev.items.push(obj.name);
?? ??? ??? ??? ?prev.count++;
???????????? },
???????????? initial: { items : [] ,count:0}
?????????? }
??????? );
[
?? ?{
?? ??? ?"category" : "fruit",
?? ??? ?"items" : [
?? ??? ??? ?"banana"
?? ??? ?],
?? ??? ?"count" : 1
?? ?},
?? ?{
?? ??? ?"category" : "veggie",
?? ??? ?"items" : [
?? ??? ??? ?"corn",
?? ??? ??? ?"broccoli"
?? ??? ?],
?? ??? ?"count" : 2
?? ?}
]

php代码如下:

$keys = array("category" => 1);
$initial = array("items" => array(),'count'=>0);
$reduce = "function (obj, prev) { " .
?? ??? ??? ?? "prev.items.push(obj.name); " .
?? ??? ??? ?? "prev.count++;" .
?? ??? ?? "}";
$cOndition= array('condition' => array("_id" => array( '$gt' => 2)));
$g = $collection->group($keys, $initial, $reduce, $condition);
print_r($g);?? //结果如下。
Array
(
??? [retval] => Array
??????? (
??????????? [0] => Array
??????????????? (
??????????????????? [category] => fruit
??????????????????? [items] => Array
??????????????????????? (
??????????????????????????? [0] => banana
??????????????????????? )
??????????????????? [count] => 1
??????????????? )
??????????? [1] => Array
??????????????? (
??????????????????? [category] => veggie
??????????????????? [items] => Array
??????????????????????? (
??????????????????????????? [0] => corn
??????????????????????????? [1] => broccoli
??????????????????????? )
??????????????????? [count] => 2
??????????????? )
??????? )
??? [count] => 3
??? [keys] => 2
??? [ok] => 1
)

3,利用aggregate group功能,也挺强大

> db.fruit.aggregate([
???????????????????? { $match: { _id: {$gt:0} } },
???????????????????? { $group: { _id: "$category", count: { $sum: 1 } } },
???????????????????? { $sort: { count: -1 } }
?????????????????? ]);
{ "_id" : "fruit", "count" : 3 }
{ "_id" : "veggie", "count" : 2 }

php代码如下:

$cOnd= array(
??? array(
??????? '$match' => array('_id' => array('$gt' => 0)),
??? ),
??? array(
??????? '$group' => array(
??????????? '_id' => '$category',
?????????? 'count' => array('$sum' => 1),
??????? ),
??? ),
??? array(
??????? '$sort' => array("count" => -1),
??? ),
);
$result = $collection->aggregate($cond);
print_r($result);    //结果如下:
Array
(
??? [result] => Array
??????? (
??????????? [0] => Array
??????????????? (
??????????????????? [_id] => fruit
??????????????????? [count] => 3
??????????????? )
??????????? [1] => Array
??????????????? (
??????????????????? [_id] => veggie
??????????????????? [count] => 2
??????????????? )
??????? )
??? [ok] => 1
)

mongodb 的select 操作有很多,在这里,只是说了一些常用的功能。

推荐阅读
  • Abp+MongoDb改造默认的审计日志存储位置
    一、背景在实际项目的开发当中,使用AbpZero自带的审计日志功能写入效率比较低。其次审计日志数据量中后期十分庞大,不适合与业务数据存放在一起。所以我们可以重新实现A ... [详细]
  • Allegro总结:1.防焊层(SolderMask):又称绿油层,PCB非布线层,用于制成丝网印板,将不需要焊接的地方涂上防焊剂.在防焊层上预留的焊盘大小要比实际的焊盘大一些,其差值一般 ... [详细]
  • MongoDB学习:(二)MongoDB简单使用
    MongoDB学习:(二)MongoDB简单使用MongoDB使用:执行mongodb的操作之前,我们需要运行命令,来进入操作命令界面>mongo提示 ... [详细]
  •     系统采用jeeplus框架(ssm+redis+shiro+mongodb+redis),默认是做了JSP未做前后端分离,由于业务需要已经多终端使用的需求(H5、小程序等) ... [详细]
  • 2018年人工智能大数据的爆发,学Java还是Python?
    本文介绍了2018年人工智能大数据的爆发以及学习Java和Python的相关知识。在人工智能和大数据时代,Java和Python这两门编程语言都很优秀且火爆。选择学习哪门语言要根据个人兴趣爱好来决定。Python是一门拥有简洁语法的高级编程语言,容易上手。其特色之一是强制使用空白符作为语句缩进,使得新手可以快速上手。目前,Python在人工智能领域有着广泛的应用。如果对Java、Python或大数据感兴趣,欢迎加入qq群458345782。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • MACElasticsearch安装步骤及验证方法
    本文介绍了MACElasticsearch的安装步骤,包括下载ZIP文件、解压到安装目录、启动服务,并提供了验证启动是否成功的方法。同时,还介绍了安装elasticsearch-head插件的方法,以便于进行查询操作。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • centos php部署到nginx 404_NodeJS项目部署到阿里云ECS服务器全程详解
    本文转载自:http:www.kovli.com20170919ecs-deploy作者:Kovli本文详细介绍如何部署NodeJS项目到阿里云ECS上, ... [详细]
  • step1.为mongodb添加admin管理员root@12.154.29.163:~#mongoMongoDBshellversionv3.4.2connectingto:mo ... [详细]
  • 一、前言在数据库中,慢查询日志通常是用来进行优化数据库,MySQL中存在慢查询,Mongodb中也是如此。在Mongo中的慢查询属于Mon ... [详细]
  • 今天我们学习,数据库mongodb的使用,最下面有mongodb的下载链接。pipinstallpymongo首先安装pymongo,然后在需要用到的地方importpymongo ... [详细]
  • mongoDB高可用集群环境搭建
    2019独角兽企业重金招聘Python工程师标准在生产环境下,部署一台mongodb服务的话,会存在以下问题:单点问题生产环境是一个 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
author-avatar
陈炘宇_573
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有