@Document(collection = "loanDetails")
class LoanDetails {
@Transient
public static final String COLLECTION_NAME = "loanDetails
@Id
String id
String loanId
String loanUUID
String loanStatus
Date loanDateCreated
Date loanLastUpdated
BigDecimal loanAmount //Stores in String
}
每当我在这个集合中保存一些数据时,我就声明了一个类LoanDetails和一个包含BigDecimal类型loanAmount的字段。
我试图在loanAmount字段上添加注释
@Field(targetType = Decimal128) // This also throws error does not contain targetType attribute attached screenshot for the same
BigDecimal loanAmount
发布于 2021-12-30 11:23:35
可能,您需要删除/迁移已经创建的loanDetails
,因为loanAmount
字段被持久化为String
。
通过将@Field(targetType = FieldType.DECIMAL128)
添加到loanAmount
字段,它应该可以工作。
import org.springframework.data.mongodb.core.mapping.FieldType;
...
@Field(targetType = FieldType.DECIMAL128)
BigDecimal loanAmount;
...
public LoanDetails() {
loanAmount = new BigDecimal(21.905334472656250);
}
...
template.save(loan);
template.find(new Query(), org.bson.Document.class, "loanDetails").forEach(l -> {
System.out.println(l.get("loanAmount").getClass().getName() + " " + l.get("loanAmount"));
});
//org.bson.types.Decimal128 21.90533447265625
template.findAll(LoanDetails.class).forEach(l -> {
System.out.println(l.loanAmount.getClass().getName() + " " + l.loanAmount);
});
//java.math.BigDecimal 21.90533447265625
如果你得到了Conversion to Decimal128 would require inexact rounding of XXX
注意:
Decimal128
类型只支持多达34位的精度。(一般情况下,“精度”=数字的总数#,小数位的“刻度”=#)。而Java BigDecimal可以更高。因此,在保存到DB之前,您需要舍入BigDecimal值(例如,使用BigDecimal.setScale()
)方法。
https://stackoverflow.com/questions/70494158
复制相似问题