我有一个交易表,其中填充了员工休假。我需要有关 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/
在控制台中反复尝试之后,我想到了这种方法,可以按发生日期对类似activerecord的(Mongoid)对象进行分组。我不确定这是完成此任务的最佳方法,但它确实有效。有没有人有更好的建议,或者这是一个很好的方法?#eventsisanarrayofactiverecord-likeobjectsthatincludeatimeattributeevents.map{|event|#converteventsarrayintoanarrayofhasheswiththedayofthemonthandtheevent{:number=>event.time.day,:event=>ev
我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re
我正在尝试用ruby中的gsub函数替换字符串中的某些单词,但有时效果很好,在某些情况下会出现此错误?这种格式有什么问题吗NoMethodError(undefinedmethod`gsub!'fornil:NilClass):模型.rbclassTest"replacethisID1",WAY=>"replacethisID2andID3",DELTA=>"replacethisID4"}end另一个模型.rbclassCheck 最佳答案 啊,我找到了!gsub!是一个非常奇怪的方法。首先,它替换了字符串,所以它实际上修改了
我有一些代码在几个不同的位置之一运行:作为具有调试输出的命令行工具,作为不接受任何输出的更大程序的一部分,以及在Rails环境中。有时我需要根据代码的位置对代码进行细微的更改,我意识到以下样式似乎可行:print"Testingnestedfunctionsdefined\n"CLI=trueifCLIdeftest_printprint"CommandLineVersion\n"endelsedeftest_printprint"ReleaseVersion\n"endendtest_print()这导致:TestingnestedfunctionsdefinedCommandLin
尝试在我的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
我正在尝试按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']
如何在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中能不能做到类似的简洁?我可以只
说在前面这部分我本来是合为一篇来写的,因为目的是一样的,都是通过独立按键来控制LED闪灭本质上是起到开关的作用,即调用函数和中断函数。但是写一篇太累了,我还是决定分为两篇写,这篇是调用函数篇。在本篇中你主要看到这些东西!!!1.调用函数的方法(主要讲语法和格式)2.独立按键如何控制LED亮灭3.程序中的一些细节(软件消抖等)1.调用函数的方法思路还是比较清晰地,就是通过按下按键来控制LED闪灭,即每按下一次,LED取反一次。重要的是,把按键与LED联系在一起。我打算用K1来作为开关,看了一下开发板原理图,K1连接的是单片机的P31口,当按下K1时,P31是与GND相连的,也就是说,当我按下去时
假设我有一个在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"}} 最佳答案 您要求一个好的方法来做到这一点,所以答案是:一种您或同事可以在六个月后理解
我基本上来自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.