java - 如何在 spring-data-mongodb 框架中将 BigDecimal 转换为 Double

标签 java spring mongodb spring-data-mongodb mongodb-java

Spring Data MongoDB 映射默认将 BigDecimal 转换为 String。但是,我希望它们在 mongodb 中转换为 Double。这是后者在 mongodb 中对该字段进行查询(比较查询/聚合查询)所必需的。 我如何注册自己的转换器 (BigDecimalToDouble/DoubleToBigDecimal) 来执行此操作?

最佳答案

以下是您可以添加自己的转换器的方法:

<bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
    <constructor-arg ref="mongoDbFactory"/>
    <constructor-arg ref="mappingConverter"/>
    <property name="writeConcern">
        <util:constant static-field="com.mongodb.WriteConcern.FSYNC_SAFE"/>
    </property>
    <property name="writeResultChecking">
        <util:constant static-field="org.springframework.data.mongodb.core.WriteResultChecking.EXCEPTION"/>
    </property>
</bean>

<mongo:mapping-converter id="mappingConverter">
    <mongo:custom-converters base-package="com.vladmihalcea.**.mongo.converter"/>
</mongo:mapping-converter>

现在您的转换器看起来像:

@Component
public class DoubleToBigDecimalConverter implements Converter<Double, BigDecimal> {

    @Override
    public BigDecimal convert(Double source) {
        return new BigDecimal(source);
    }
}

@Component
public class BigDecimalToDoubleConverter implements Converter<BigDecimal, Double> {

    @Override
    public Double convert(BigDecimal source) {
        return source.doubleValue();
    }
}

在添加转换器之前我得到:

update test.product query: { _id: 123 } update: { _id: 123, _class: "com.vladmihalcea.mongo.model.Product", name: "Tv", quantity: "10", discount: "12.34", version: 0 } nscanned:0 nupdated:1 upsert:1 keyUpdates:0 locks(micros) w:49328 50ms

添加转换器后:

update test.product query: { _id: 123 } update: { _id: 123, _class: "com.vladmihalcea.mongo.model.Product", name: "Tv", quantity: "10", discount: 12.34, version: 0 } nscanned:0 nupdated:1 upsert:1 keyUpdates:0 locks(micros) w:64689 65ms

关于java - 如何在 spring-data-mongodb 框架中将 BigDecimal 转换为 Double,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23358778/

相关文章:

mongodb - 插入 + 更新/更新插入?

node.js - 是否编写node.js api回调

mysql - 建议频繁写入,很少读取数据库

java - 禁用 Pane 子项上的所有鼠标事件

java - 如何通过 Java Validator 消息传递参数?

Spring test-mvc PUT 不支持

java - 如何使受管实体具有上下文感知能力?

spring - Elasticsearch API与Spring数据与Logstash

java - Sw架构-java模块之间的通信

java - Spring Data Neo4j 将不同的类合并到一个 NodeEntity 中