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

mongo学习group操作以及java代码

原数据:*1*{_id:ObjectId(552a330e05c27486b9b9b650),_class:com.mongo.model.Order

 

 

原数据:

/* 1 */
{"_id" : ObjectId("552a330e05c27486b9b9b650"),"_class" : "com.mongo.model.Orders","onumber" : "002","date" : ISODate("2014-01-03T16:03:00.000Z"),"cname" : "zcy","item" : {"quantity" : 1.0,"price" : 4.0,"pnumber" : "p002"}
}/* 2 */
{"_id" : ObjectId("552a331d05c275d8590a550d"),"_class" : "com.mongo.model.Orders","onumber" : "003","date" : ISODate("2014-01-04T16:03:00.000Z"),"cname" : "zcy","item" : {"quantity" : 10.0,"price" : 2.0,"pnumber" : "p001"}
}/* 3 */
{"_id" : ObjectId("552a333105c2f28194045a72"),"_class" : "com.mongo.model.Orders","onumber" : "003","date" : ISODate("2014-01-04T16:04:00.000Z"),"cname" : "zcy","item" : {"quantity" : 30.0,"price" : 4.0,"pnumber" : "p002"}
}/* 4 */
{"_id" : ObjectId("552a333f05c2b62c01cff50e"),"_class" : "com.mongo.model.Orders","onumber" : "004","date" : ISODate("2014-01-05T16:03:00.000Z"),"cname" : "zcy","item" : {"quantity" : 5.0,"price" : 4.0,"pnumber" : "p002"}
}

  

一。mongo语句

db.orders.group({key:{date:1,"item.pnumber" : 1},initial:{"total":0},reduce:function Reduce(doc,out){out.total+=doc.item.price}})

  

 

 

 

对out数据进一步处理db.orders.group({key: {date: 1},initial: {"total": 0,"money":0},reduce: function Reduce(doc, out) {out.total += doc.item.quantity;out.money += doc.item.price*doc.item.quantity},finalize:function Finalize(out){out.avg=out.money/out.totalreturn out}})

  

 

 

keyf :对分组字段先进行处理然后分组db.orders.group({keyf: function keysss(doc){return {"month":doc.date.getDay()+1} },initial: {"total": 0,"money":0},reduce: function Reduce(doc, out) {out.total += doc.item.quantity;out.money += doc.item.price*doc.item.quantity},finalize:function Finalize(out){out.avg=out.money/out.totalreturn out}})

  

 

java代码:

@Testpublic void group(){ApplicationContext applicationContext=new ClassPathXmlApplicationContext("classpath:111.xml");MongoTemplate mongoTemplate= (MongoTemplate) applicationContext.getBean("mongoTemplate");GroupBy groupBy=new GroupBy("date");BasicDBObject basicDBObject=new BasicDBObject();basicDBObject.put("total",0);basicDBObject.put("money",0);groupBy.initialDocument(basicDBObject);groupBy.reduceFunction("function Reduce(doc, out) {out.total += doc.item.quantity;out.money += doc.item.price*doc.item.quantity}");groupBy.finalizeFunction("function Finalize(out){\n" +" out.avg=out.money/out.total\n" +" return out\n" +" }");
// groupBy.finalizeFunction("function Finalize(out) {out.avg = out.money / out.totalreturn out}");GroupByResults orders = mongoTemplate.group("orders", groupBy, Object.class);}

  

 

转:https://www.cnblogs.com/anxbb/p/9480596.html



推荐阅读
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • JDK源码学习之HashTable(附带面试题)的学习笔记
    本文介绍了JDK源码学习之HashTable(附带面试题)的学习笔记,包括HashTable的定义、数据类型、与HashMap的关系和区别。文章提供了干货,并附带了其他相关主题的学习笔记。 ... [详细]
  • YOLOv7基于自己的数据集从零构建模型完整训练、推理计算超详细教程
    本文介绍了关于人工智能、神经网络和深度学习的知识点,并提供了YOLOv7基于自己的数据集从零构建模型完整训练、推理计算的详细教程。文章还提到了郑州最低生活保障的话题。对于从事目标检测任务的人来说,YOLO是一个熟悉的模型。文章还提到了yolov4和yolov6的相关内容,以及选择模型的优化思路。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • React项目中运用React技巧解决实际问题的总结
    本文总结了在React项目中如何运用React技巧解决一些实际问题,包括取消请求和页面卸载的关联,利用useEffect和AbortController等技术实现请求的取消。文章中的代码是简化后的例子,但思想是相通的。 ... [详细]
  • Monkey《大话移动——Android与iOS应用测试指南》的预购信息发布啦!
    Monkey《大话移动——Android与iOS应用测试指南》的预购信息已经发布,可以在京东和当当网进行预购。感谢几位大牛给出的书评,并呼吁大家的支持。明天京东的链接也将发布。 ... [详细]
author-avatar
手机用户2502929967
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有