我有我的收藏作为
学生
{
"first_name":"Harew",
"last_name":"Jackson",
"class":14,
"fee": [
{ "tuition":48500.2456, "transportation":500 }
]
}
我需要根据 fee = 4500.24 过滤学生,它应该显示
所有学生的费用为 4500.24,忽略小数点后的其他数字。
我在MongoDB: How to get N decimals precision in a query中搜索过
precision-in-a-query 但这里提供的解决方案在我的场景中不起作用,因为
"$mod": [ "$amount.value", 0.01 ] 不适用于 BigDecimal 类型,在我的收藏中,费用类型为 BigDecimal.
以下解决方案似乎运行良好,但我不知道如何在 Scala 中实现它
db.collection.find({
"$where": function() {
return Math.round(this.fee.school * 100)/ 100 === 1.12;
}
})
最佳答案
您可以轻松地将 BigDecimal 中的值四舍五入为特定精度,如果需要,您还可以同时将其转换为 double 值。 例如:-
scala> val s :BigDecimal = 10.232 s: BigDecimal = 10.232
scala> s.setScale(2, BigDecimal.RoundingMode.HALF_UP).toDouble res1: Double = 10.23//转换为 DOUBLE
scala> s.setScale(2, BigDecimal.RoundingMode.HALF_UP) res2: scala.math.BigDecimal = 10.23//舍入
所以在 scala 中,您可以使用 setScale 而不是使用 math.Round。
关于mongodb - 在 mongodb 中四舍五入到小数点后两位,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41972680/
我正在我的应用程序中存储成本。成本未在数据库中格式化。例如:00.00存为0,1.00存为1,40.50存为40.5我需要从数据库中读取这些值并将它们转换为表示美元和美分的字符串。例如:0-->cost_dollars="00"&cost_cents="00",1-->cost_dollars="01"&cost_cents="00",40.5-->cost_dollars="40"&cost_cents="50".在rubyonrails中有没有一种简单的方法可以做到这一点?或者有人有执行此操作的代码吗?谢谢! 最佳答案 您可
我有一个评论模型,允许对产品进行“1-10”评级系统。在我的表单View中,这是我在该字段中吐出1-10的下拉列表的方式...效果很好,但团队现在希望评级系统有0.5个小数,因此可以将某些内容评级为7.5、8.0、8.5等。然而,这让我感到难过...我如何才能在Ruby中更改上面的代码并遍历一组数字并将其递增0.5?(注意:是的,我已经将评分列从整数转换为float。) 最佳答案 你可以这样定义增量(0..10).step(0.5) 关于ruby-on-rails-RubyonRails
我需要像这样格式化小数:00.3311.2405.22问题是,当我检索00.33时,它输出为0.33。我尝试了所有方法,但无法正常工作。我可以执行MySQL的Zerofill,但我确实在努力避免这种情况。 最佳答案 sprintf("%05.2f",0.33)#or"%05.2f"%0.33 关于ruby-on-rails-如何格式化小数?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questi
Ruby正确解析第一个日期,但第二个日期不正确。使用ruby1.9.3和2.1.2测试。知道如何让它始终如一地工作吗?(我们将出生日期设为2位数年份)Date.strptime("10/11/89","%d/%m/%y")=>Fri,10Nov1989Date.strptime("15/10/63","%d/%m/%y")=>Mon,15Oct2063 最佳答案 strptime方法将文本“63”解析为2063年,而不是您想要的1963年。这是因为该方法使用POSIXstandard来决定世纪。.chronicgem也有类似的问
整数或小数是否有等效的gsub?gsub应该使用整数吗?基本上,我只是想将小数输入到ruby表单中,以及用户能够使用逗号的内容。例如,我希望用户能够输入1,000.99。我试过用before_save:strip_commasdefstrip_commasself.number=self.number.gsub(",","")end但出现以下错误“undefinedmethod`gsub'for8:Fixnum”,其中“8”被替换为用户输入的任何数字。 最佳答案 如果您的字段是Fixnum,它永远不会有逗号,因为Rails必须将
我有一个动态生成的表格,它乘以价格*数量。部分价格以美分计算。例如如果某件商品的价格是0.0375,我可以在我的表格中将其显示为number_to_currency(0.0375,:precision=>4)=>$0.0375但是我得到的价格是标准的2位小数的数量number_to_currency(33.95,:precision=>4)=>$39.9500我需要一种方法来去除十进制值的尾随零。请记住,输出位于Model.eachblock中,因此我不确定是否可以有条件地修改精度参数。 最佳答案 尝试指定strip_insigni
我可以在一个Rails应用程序中同时使用MongoDB和PostgreSQL吗?具体来说,我最终会想要使用像MongoHQ这样的东西。到目前为止,我未能在实验中进行这项工作。令我担心的是,MongoDB文档特别指出我必须禁用ActiveRecord。任何建议将不胜感激。 最佳答案 您无需禁用ActiveRecord即可使用MongoDB。查看Mongoid只需将gem加上任何模型与您现有的任何ActiveRecord模型一起添加。您应该注意到MongoHQ只是MongoDB的托管服务,可以与任何对象文档映射器(ODM)一起使用。更多
我必须在mongoid模型中添加几个字段,我知道MongoDB没有迁移,但如果我继续而不删除数据库,使rails完全“重新生成”数据库,它不会显示或使用新的领域!去这里最好的方法是什么?有比删除/重新打开mongodb更软的东西吗?提前致谢卢卡 最佳答案 一般来说,应该可以在运行时用新字段更新旧文档。MongoDB中不需要迁移。您可能想编写rake任务以使用新字段和默认值更新旧文档。您可以通过检查那些默认值为nil的新字段来找到这些文档。更新简单风格:如果您使用默认值定义一个新字段,只要您设置了一个新值,就应该始终使用该值:应用程序
我如何从Ruby代码连接到mongodb? 最佳答案 首先,您必须安装MongoDbgem:geminstallmongo然后运行代码:require'rubygems'#notnecessaryforRuby1.9require'mongo'db=Mongo::Connection.new.db("mydb")#ORdb=Mongo::Connection.new("localhost").db("mydb")#ORdb=Mongo::Connection.new("localhost",27017).db("mydb")
我正在尝试使用聚合框架(使用ruby)并像这样投影日期:db['requests'].aggregate([{"$project"=>{_id:0,method:'$method',user:'$user',year:{'$year'=>'$timestamp'}}}])文档是这样的:{_id:ObjectId("5177d7d7df26358289da7dfd"),timestamp:ISODate("2013-04-12T03:58:05+00:00"),method:"POST",status:"200",inputsize:"874",outputsize:"4981",u