我有一个聚合脚本,它让我得到一个如下所示的结果集:
{
"_id" : "SI-3",
"party_uuid" : "dfa1e80a-5521-11e6-beb8-9e71128cae77",
"transaction_date" : ISODate("2016-04-14T00:00:00.201+0000"),
"transaction_net_value" : 1666.67,
"object_category" : "Revenue",
"object_origin_category" : "Bookkeeping",
"object_origin" : "Sage One",
"item_quantity" : NumberInt(10),
"item_name" : "Product Three",
"item_category" : "Sales Revenue",
"item_ net_total_value" : 1666.67
}
{
"_id" : "SI-2",
"party_uuid" : "dfa1e80a-5521-11e6-beb8-9e71128cae77",
"transaction_date" : ISODate("2016-05-19T00:00:00.201+0000"),
"transaction_net_value" : NumberInt(1500),
"object_category" : "Revenue",
"object_origin_category" : "Bookkeeping",
"object_origin" : "Sage One",
"item_quantity" : NumberInt(1),
"item_name" : "Product One",
"item_category" : "Sales Revenue",
"item_ net_total_value" : NumberInt(1500)
}
{
"_id" : "SI-15",
"party_uuid" : "dfa1e80a-5521-11e6-beb8-9e71128cae77",
"transaction_date" : ISODate("2016-07-11T00:00:00.201+0000"),
"transaction_net_value" : 8333.33,
"object_category" : "Revenue",
"object_origin_category" : "Bookkeeping",
"object_origin" : "Sage One",
"item_quantity" : NumberInt(7),
"item_name" : "Product Four",
"item_category" : "Sales Revenue",
"item_ net_total_value" : 8333.33
}
{
"_id" : "SI-14",
"party_uuid" : "dfa1e80a-5521-11e6-beb8-9e71128cae77",
"transaction_date" : ISODate("2016-07-11T00:00:00.201+0000"),
"transaction_net_value" : NumberInt(7500),
"object_category" : "Revenue",
"object_origin_category" : "Bookkeeping",
"object_origin" : "Sage One",
"item_quantity" : NumberInt(6),
"item_name" : "Product Four",
"item_category" : "Sales Revenue",
"item_ net_total_value" : NumberInt(7500)
}
{
"_id" : "SI-1",
"party_uuid" : "dfa1e80a-5521-11e6-beb8-9e71128cae77",
"transaction_date" : ISODate("2016-06-16T00:00:00.201+0000"),
"transaction_net_value" : NumberInt(1500),
"object_category" : "Revenue",
"object_origin_category" : "Bookkeeping",
"object_origin" : "Sage One",
"item_quantity" : NumberInt(1),
"item_name" : "Product One",
"item_category" : "Sales Revenue",
"item_ net_total_value" : NumberInt(1500)
}
{
"_id" : "SI-1",
"party_uuid" : "dfa1e80a-5521-11e6-beb8-9e71128cae77",
"transaction_date" : ISODate("2016-06-16T00:00:00.201+0000"),
"transaction_net_value" : NumberInt(1500),
"object_category" : "Revenue",
"object_origin_category" : "Bookkeeping",
"object_origin" : "Sage One",
"item_quantity" : NumberInt(1),
"item_name" : "Product Twenty Two",
"item_category" : "Sales Revenue",
"item_ net_total_value" : NumberInt(1500)
}
当我添加如下所示的最后阶段时,我得到的结果并不像预期的那样$sum。当它显然不是 0 时,我得到 0。知道我在 $group 阶段做错了什么吗?
$group : {
_id: {"party_uuid" : "$party_uuid",
"transaction_year" : {$year : "$transaction_date"},
"transaction_month" : {$month : "$transaction_date"},
"category" : "$item_category",
"object_origin_category" : "$object_origin_category",
"object_origin" : "$object_origin"},
"month_net_value" : { $sum: "$item_net_total_value" }
}
这个结果
{
"_id" : {
"party_uuid" : "dfa1e80a-5521-11e6-beb8-9e71128cae77",
"transaction_year" : NumberInt(2016),
"transaction_month" : NumberInt(6),
"category" : "Sales Revenue",
"object_origin_category" : "Bookkeeping",
"object_origin" : "Sage One"
},
"month_net_value" : NumberInt(0)
}
{
"_id" : {
"party_uuid" : "dfa1e80a-5521-11e6-beb8-9e71128cae77",
"transaction_year" : NumberInt(2016),
"transaction_month" : NumberInt(5),
"category" : "Sales Revenue",
"object_origin_category" : "Bookkeeping",
"object_origin" : "Sage One"
},
"month_net_value" : NumberInt(0)
}
{
"_id" : {
"party_uuid" : "dfa1e80a-5521-11e6-beb8-9e71128cae77",
"transaction_year" : NumberInt(2016),
"transaction_month" : NumberInt(7),
"category" : "Sales Revenue",
"object_origin_category" : "Bookkeeping",
"object_origin" : "Sage One"
},
"month_net_value" : NumberInt(0)
}
{
"_id" : {
"party_uuid" : "dfa1e80a-5521-11e6-beb8-9e71128cae77",
"transaction_year" : NumberInt(2016),
"transaction_month" : NumberInt(4),
"category" : "Sales Revenue",
"object_origin_category" : "Bookkeeping",
"object_origin" : "Sage One"
},
"month_net_value" : NumberInt(0)
}
再次感谢
最佳答案
可能是您的 key 中有空格:
"item_ net_total_value"
比较:
"$item_net_total_value"
关于Mongodb 组和总和不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38709020/
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象
我目前正在尝试学习RubyonRails和测试框架RSpec。assigns在此RSpec测试中做什么?describe"GETindex"doit"assignsallmymodelas@mymodel"domymodel=Factory(:mymodel)get:indexassigns(:mymodels).shouldeq([mymodel])endend 最佳答案 assigns只是检查您在Controller中设置的实例变量的值。这里检查@mymodels。 关于ruby-o
这段代码似乎创建了一个范围从a到z的数组,但我不明白*的作用。有人可以解释一下吗?[*"a".."z"] 最佳答案 它叫做splatoperator.SplattinganLvalueAmaximumofonelvaluemaybesplattedinwhichcaseitisassignedanArrayconsistingoftheremainingrvaluesthatlackcorrespondinglvalues.Iftherightmostlvalueissplattedthenitconsumesallrvaluesw
你能解释一下吗?我想评估来自两个不同来源的值和计算。一个消息来源为我提供了以下信息(以编程方式):'a=2'第二个来源给了我这个表达式来评估:'a+3'这个有效:a=2eval'a+3'这也有效:eval'a=2;a+3'但我真正需要的是这个,但它不起作用:eval'a=2'eval'a+3'我想了解其中的区别,以及如何使最后一个选项起作用。感谢您的帮助。 最佳答案 您可以创建一个Binding,并将相同的绑定(bind)与每个eval相关联调用:1.9.3p194:008>b=binding=>#1.9.3p194:009>eva
我无法运行Spring。这是错误日志。myid-no-MacBook-Pro:myid$spring/Users/myid/.rbenv/versions/1.9.3-p484/lib/ruby/gems/1.9.1/gems/spring-0.0.10/lib/spring/sid.rb:17:in`fiddle_func':uninitializedconstantSpring::SID::DL(NameError)from/Users/myid/.rbenv/versions/1.9.3-p484/lib/ruby/gems/1.9.1/gems/spring-0.0.10/li
以前没见过这个,但我想知道如何在Ruby中找到二维数组的两条对角线之和。假设您有一个简单的数组,包含3行和3列。array=[1,2,3,4,5,6,7,8,9]我可以通过使用将它分成三个一组array.each_slice(3).to_a现在是[1,2,3],[4,5,6],[7,8,9][1,2,3][4,5,6][7,8,9]在这种情况下,对角线是1+5+9=153+5+7=15所以总和为15+15=30我想我可以做类似的事情diagonal_sum=0foriin0..2forjin0..2diagonal_sum+=array[i][j]endend
我在RoR应用程序中有一个提交表单,是使用simple_form构建的。当字段为空白时,应用程序仍会继续下一步,而不会提示错误或警告。默认情况下,这些字段应该是required:true;但即使手动编写也行不通。该应用有3个步骤:NewPost(新View)->Preview(创建View)->Post。我的Controller和View的摘录会更清楚:defnew@post=Post.newenddefcreate@post=Post.new(params.require(:post).permit(:title,:category_id))ifparams[:previewButt
我有一个字符串数组,我需要从中提取第一个单词,将它们转换为整数并获得它们的总和。示例:["5Apple","5Orange","15Grapes"]预期输出=>25我的尝试:["5","5","15"].map(&:to_i).sum 最佳答案 我从你的问题中找到了答案。["5Apple","5Orange","15Grapes"].map(&:to_i).sum在数组中,如果存在任何整数可转换值,那么它将自动转换为整数。 关于arrays-字符串数组中字符串第一部分的总和,我们在Sta
我一直在Heroku上尝试不同的缓存策略,并添加了他们的memcached附加组件,目的是为我的应用程序添加Action缓存。但是,当我在我当前的应用程序上查看Rails.cache.stats时(安装了memcached并使用dalligem),在执行应该缓存的操作后,我得到current和total_items为0。在Controller的顶部,我想缓存我有的Action:caches_action:show此外,我修改了我的环境配置(对于在Heroku上运行的配置)config.cache_store=:dalli_store我是否可以查看其他一些统计数据,看看它是否有效或我做错
我在我的机器上安装了ruby版本1.9.3,并且正在为我的个人网站开发一个octopress项目。我为我的gems使用了rvm,并遵循了octopress.org记录的所有步骤。但是我在我的rake服务器中发现了一些错误。这是我的命令日志。Tin-Aung-Linn:octopresstal$ruby--versionruby1.9.3p448(2013-06-27revision41675)[x86_64-darwin12.4.0]Tin-Aung-Linn:octopresstal$rakegenerate##GeneratingSitewithJekyllidenticals