我需要将金融数据保存到云数据存储(而不是通过appengine,使用云数据存储API beta);价格信息使用BigDecimal存储在我们的对象中。
根据api文档,只有double和long作为数字类型被支持。
我担心使用BigDecimal的doubleValue()方法节省价格,因为它具有双重和精确性,另一种方法是使用toString并将其保存为字符串,但这感觉效率很低。
你认为合适的方法是什么?
谢谢
发布于 2016-04-07 10:33:33
我建议将其保存为String值(特别是如果是财务数据)。因为这样就可以通过BigDecimal(String)构造函数以完全可预测的结果恢复值。
参见BigDecimal(double)构造函数在其javadoc中的注释。
发布于 2020-03-29 00:56:38
String是可以的。或者,如果需要对金额进行排序/筛选,则将值乘以所需的小数位数,并将其存储为Long。
例如:货币金额。$10.23x100= 1023。
https://stackoverflow.com/questions/36388286
复制相似问题