草庐IT

Mongodb 不同的计数,按多列分组的求和函数

coder 2023-11-06 原文

我有一个交易表,其中填充了员工休假。我需要有关 mongodb 中以下 sql 场景的帮助。

从中选择员工、月、年、计数(不同的(假期类型)、总和(小时) 按员工、月、年分组交易

几周前我开始使用 mongodb。我通过堆栈溢出帖子得到了部分答案 Mongodb count distinct with multiple group fields现在我想添加求和功能。

任何指导都会非常有帮助,这里是一个以表格形式显示的数据示例:

Employee    date      holiday_type  hours
1           1/1/2014  1             8 
1           1/5/2014  2             7 
1           2/15/2014 1             8 
1           3/15/2014 3             16 
11          1/1/2014  1             8 
11          1/5/2014  1             6 
11          2/15/2014 3             8 
11          3/15/2014 3             8

最佳答案

因此,“小时”实际上是文档中的一个字段(属性)。因此,根据之前的答案,您只需将双重分组抽象如下:

db.transactions.aggregate([
    { "$group": { 
        "_id": { 
            "employee" : "$employee",
            "Month": { "$month" : "$date" }, 
            "Year": { "$year" : "$date" },
            "holiday_type" : "$holiday_type"
        },
        "hours": { "$sum": "$hours" }
     }},
     { "$group": {
         "_id": {
            "employee" : "$_id.employee",
            "Month": "$_id.Month",
            "Year": "$_id.Year"
         },
         "count": { "$sum": 1 },
         "hours": { "$sum": "$hours" }
     }}
 ], { "allowDiskUse": true }
 );

所以你只是在使用 $sum在两个阶段。

此外,您应该值得一看 SQL to Aggregation mapping chart官方文档中提供。它有许多常见的 SQL 操作示例以及如何以 MongoDB 方式实现它们。


来自你自己的数据,但由我自己以这种方式插入:

db.transactions.insert([
    { "employee": 1,  "date": new Date("2014-01-01"), "holiday_type":  1, "hours": 8   },
    { "employee": 1,  "date": new Date("2014-01-05"), "holiday_type":  2, "hours": 7   },
    { "employee": 1,  "date": new Date("2014-02-15"), "holiday_type":  1, "hours": 8   },
    { "employee": 1,  "date": new Date("2014-03-15"), "holiday_type":  3, "hours": 16  },
    { "employee": 11, "date": new Date("2014-01-01"), "holiday_type":  1, "hours": 8   },
    { "employee": 11, "date": new Date("2014-01-05"), "holiday_type":  1, "hours": 6   },
    { "employee": 11, "date": new Date("2014-02-15"), "holiday_type":  1, "hours": 8   },
    { "employee": 11, "date": new Date("2014-03-15"), "holiday_type":  3, "hours": 8   }
])

这不是最好的例子,因为所有月份实际上都不同,但如果需要以这种方式分组,这将在“holiday_type”上获得“不同”的值。结果实现:

{
    "_id" : {
            "employee" : 1,
            "Month" : 2,
            "Year" : 2014
    },
    "count" : 1,
    "hours" : 8
}
{
    "_id" : {
            "employee" : 11,
            "Month" : 2,
            "Year" : 2014
    },
    "count" : 1,
    "hours" : 8
}
{
    "_id" : {
            "employee" : 1,
            "Month" : 1,
            "Year" : 2014
    },
    "count" : 2,
    "hours" : 15
}
{
    "_id" : {
            "employee" : 11,
            "Month" : 1,
            "Year" : 2014
    },
    "count" : 1,
    "hours" : 14
}
{
    "_id" : {
            "employee" : 1,
            "Month" : 3,
            "Year" : 2014
    },
    "count" : 1,
    "hours" : 16
}
{
    "_id" : {
            "employee" : 11,
            "Month" : 3,
            "Year" : 2014
    },
    "count" : 1,
    "hours" : 8
}

关于Mongodb 不同的计数,按多列分组的求和函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23652591/

有关Mongodb 不同的计数,按多列分组的求和函数的更多相关文章

  1. ruby-on-rails - 按天对 Mongoid 对象进行分组 - 2

    在控制台中反复尝试之后,我想到了这种方法,可以按发生日期对类似activerecord的(Mongoid)对象进行分组。我不确定这是完成此任务的最佳方法,但它确实有效。有没有人有更好的建议,或者这是一个很好的方法?#eventsisanarrayofactiverecord-likeobjectsthatincludeatimeattributeevents.map{|event|#converteventsarrayintoanarrayofhasheswiththedayofthemonthandtheevent{:number=>event.time.day,:event=>ev

  2. ruby - 在没有 sass 引擎的情况下使用 sass 颜色函数 - 2

    我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re

  3. ruby-on-rails - 在 ruby​​ 中使用 gsub 函数替换单词 - 2

    我正在尝试用ruby​​中的gsub函数替换字符串中的某些单词,但有时效果很好,在某些情况下会出现此错误?这种格式有什么问题吗NoMethodError(undefinedmethod`gsub!'fornil:NilClass):模型.rbclassTest"replacethisID1",WAY=>"replacethisID2andID3",DELTA=>"replacethisID4"}end另一个模型.rbclassCheck 最佳答案 啊,我找到了!gsub!是一个非常奇怪的方法。首先,它替换了字符串,所以它实际上修改了

  4. ruby - 在 Ruby 中有条件地定义函数 - 2

    我有一些代码在几个不同的位置之一运行:作为具有调试输出的命令行工具,作为不接受任何输出的更大程序的一部分,以及在Rails环境中。有时我需要根据代码的位置对代码进行细微的更改,我意识到以下样式似乎可行:print"Testingnestedfunctionsdefined\n"CLI=trueifCLIdeftest_printprint"CommandLineVersion\n"endelsedeftest_printprint"ReleaseVersion\n"endendtest_print()这导致:TestingnestedfunctionsdefinedCommandLin

  5. ruby-on-rails - Ruby on Rails 计数器缓存错误 - 2

    尝试在我的RoR应用程序中实现计数器缓存列时出现错误Unknownkey(s):counter_cache。我在这个问题中实现了模型关联:Modelassociationquestion这是我的迁移:classAddVideoVotesCountToVideos0Video.reset_column_informationVideo.find(:all).eachdo|p|p.update_attributes:videos_votes_count,p.video_votes.lengthendenddefself.downremove_column:videos,:video_vot

  6. ruby - 使用多个数组创建计数 - 2

    我正在尝试按0-9和a-z的顺序创建数字和字母列表。我有一组值value_array=['0','1','2','3','4','5','6','7','8','9','a','b','光盘','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','','u','v','w','x','y','z']和一个组合列表的数组,按顺序,这些数字可以产生x个字符,比方说三个list_array=[]和一个当前字母和数字组合的数组(在将它插入列表数组之前我会把它变成一个字符串,]current_combo['0','0','0']

  7. ruby - 在 Ruby 中按名称传递函数 - 2

    如何在Ruby中按名称传递函数?(我使用Ruby才几个小时,所以我还在想办法。)nums=[1,2,3,4]#Thisworks,butismoreverbosethanI'dlikenums.eachdo|i|putsiend#InJS,Icouldjustdosomethinglike:#nums.forEach(console.log)#InF#,itwouldbesomethinglike:#List.iternums(printf"%A")#InRuby,IwishIcoulddosomethinglike:nums.eachputs在Ruby中能不能做到类似的简洁?我可以只

  8. C51单片机——实现用独立按键控制LED亮灭(调用函数篇) - 2

    说在前面这部分我本来是合为一篇来写的,因为目的是一样的,都是通过独立按键来控制LED闪灭本质上是起到开关的作用,即调用函数和中断函数。但是写一篇太累了,我还是决定分为两篇写,这篇是调用函数篇。在本篇中你主要看到这些东西!!!1.调用函数的方法(主要讲语法和格式)2.独立按键如何控制LED亮灭3.程序中的一些细节(软件消抖等)1.调用函数的方法思路还是比较清晰地,就是通过按下按键来控制LED闪灭,即每按下一次,LED取反一次。重要的是,把按键与LED联系在一起。我打算用K1来作为开关,看了一下开发板原理图,K1连接的是单片机的P31口,当按下K1时,P31是与GND相连的,也就是说,当我按下去时

  9. ruby - 在 Ruby 中创建按公共(public)键值分组的新哈希 - 2

    假设我有一个在Ruby中看起来像这样的哈希:{:ie0=>"Hi",:ex0=>"Hey",:eg0=>"Howdy",:ie1=>"Hello",:ex1=>"Greetings",:eg1=>"Goodday"}有什么好的方法可以将它变成如下内容:{"0"=>{"ie"=>"Hi","ex"=>"Hey","eg"=>"Howdy"},"1"=>{"ie"=>"Hello","ex"=>"Greetings","eg"=>"Goodday"}} 最佳答案 您要求一个好的方法来做到这一点,所以答案是:一种您或同事可以在六个月后理解

  10. java - 为什么 ruby​​ modulo 与 java/other lang 不同? - 2

    我基本上来自Java背景并且努力理解Ruby中的模运算。(5%3)(-5%3)(5%-3)(-5%-3)Java中的上述操作产生,2个-22个-2但在Ruby中,相同的表达式会产生21个-1-2.Ruby在逻辑上有多擅长这个?模块操作在Ruby中是如何实现的?如果将同一个操作定义为一个web服务,两个服务如何匹配逻辑。 最佳答案 在Java中,模运算的结果与被除数的符号相同。在Ruby中,它与除数的符号相同。remainder()在Ruby中与被除数的符号相同。您可能还想引用modulooperation.

随机推荐