Spring 使用 MongoDB 时的数据类型转换器

官方文档:自定义类型转换器

是时间戳为例的代码:

TimestampReadConverter.java

import org.bson.BsonTimestamp;
import org.springframework.core.convert.converter.Converter;

import java.time.Instant;
import java.util.Date;

/*
* Java类型与 MongoDB 数据类型的对应关系
*
* 如果 MongoDB 集合中字段类型是 timestamp ,则对应Java端的 BsonTimestamp,精确到秒,说主要是 MongoDB 内部使用;
* 应用如果要记录时间,可以使用 Date 类型(精确到毫秒),对应Java端的 Instant / LocalDateTime,无需自定义转换器
* */

public class TimestampReadConverter implements Converter<BsonTimestamp, Date> {
    @Override
    public Date convert(BsonTimestamp source) {
//        System.out.println("BsonTimestamp 转 Date");
        //Bson规范 :https://bsonspec.org/spec.html
        // UTC datetime - The int64 is UTC milliseconds since the Unix epoch.
        // Timestamp - Special internal type used by MongoDB replication and sharding.
        // First 4 bytes are an increment, second 4 are a timestamp.
        Instant instant = Instant.ofEpochSecond(source.getTime());
        return Date.from(instant);
    }
}

TimestampWriteConverter.java

import org.bson.BsonTimestamp;
import org.springframework.core.convert.converter.Converter;
import org.springframework.data.convert.WritingConverter;

import java.util.Date;

@WritingConverter
public class TimestampWriteConverter implements Converter<Date, BsonTimestamp> {
    @Override
    public BsonTimestamp convert(Date source) {
//        System.out.println("Date 转 BsonTimestamp");
        return new BsonTimestamp((int) source.toInstant().getEpochSecond(), 0);
    }
}

MongoDBConfig.java

import org.springframework.context.annotation.Configuration;
import org.springframework.data.mongodb.config.AbstractMongoClientConfiguration;
import org.springframework.data.mongodb.core.convert.MongoCustomConversions;

import java.util.Collection;

@Configuration
public class MongoDBConfig extends AbstractMongoClientConfiguration {

    @Override
    protected void configureConverters(MongoCustomConversions.MongoConverterConfigurationAdapter adapter) {
        //用 Lambda 表达式,编译不过
//        adapter.registerConverter((BsonTimestamp source) -> Date.from(Instant.ofEpochSecond(source.getTime())));
//        adapter.registerConverter((Date source) -> new BsonTimestamp((int) source.toInstant().getEpochSecond(), 0));

        adapter.registerConverter(new TimestampReadConverter());
        adapter.registerConverter(new TimestampWriteConverter());
    }

    /* The mapping base package defines the root path used to scan for
    entities used to pre initialize the MappingContext. By default, the
    configuration classes package is used.*/
    @Override
    protected Collection<String> getMappingBasePackages() {
        return super.getMappingBasePackages();
    }

    @Override
    protected String getDatabaseName() {
        return "testdata";
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot中使用MongoDB切换数据源,可以通过创建多个MongoDB的连接配置和使用`@Qualifier`注解来实现。下面是具体的步骤: 1. 配置多个MongoDB连接信息 在`application.properties`文件中,配置多个MongoDB连接信息,例如: ``` # MongoDB1 spring.data.mongodb1.uri=mongodb://localhost:27017/db1 spring.data.mongodb1.database=db1 spring.data.mongodb1.authentication-database=admin spring.data.mongodb1.username=user1 spring.data.mongodb1.password=password1 # MongoDB2 spring.data.mongodb2.uri=mongodb://localhost:27017/db2 spring.data.mongodb2.database=db2 spring.data.mongodb2.authentication-database=admin spring.data.mongodb2.username=user2 spring.data.mongodb2.password=password2 ``` 2. 创建多个MongoDB的连接配置 创建多个MongoDB的连接配置类,例如: ``` @Configuration @EnableMongoRepositories(basePackages = "com.example.db1.repositories", mongoTemplateRef = "mongoDb1Template") public class MongoDb1Config { @Bean(name = "mongoDb1Template") public MongoTemplate mongoTemplate(@Qualifier("mongoDb1Factory") MongoDbFactory mongoDbFactory) { return new MongoTemplate(mongoDbFactory); } @Bean(name = "mongoDb1Factory") public MongoDbFactory mongoDbFactory() { MongoClientURI uri = new MongoClientURI("mongodb://localhost:27017/db1"); MongoClient mongoClient = new MongoClient(uri); return new SimpleMongoDbFactory(mongoClient, "db1"); } } @Configuration @EnableMongoRepositories(basePackages = "com.example.db2.repositories", mongoTemplateRef = "mongoDb2Template") public class MongoDb2Config { @Bean(name = "mongoDb2Template") public MongoTemplate mongoTemplate(@Qualifier("mongoDb2Factory") MongoDbFactory mongoDbFactory) { return new MongoTemplate(mongoDbFactory); } @Bean(name = "mongoDb2Factory") public MongoDbFactory mongoDbFactory() { MongoClientURI uri = new MongoClientURI("mongodb://localhost:27017/db2"); MongoClient mongoClient = new MongoClient(uri); return new SimpleMongoDbFactory(mongoClient, "db2"); } } ``` 3. 在DAO层使用`@Qualifier`注解 在DAO层使用`@Qualifier`注解指定使用哪个MongoDB连接,例如: ``` @Repository public class UserRepository { @Autowired @Qualifier("mongoDb1Template") private MongoTemplate mongoDb1Template; @Autowired @Qualifier("mongoDb2Template") private MongoTemplate mongoDb2Template; public void saveUser1(User user) { mongoDb1Template.save(user); } public void saveUser2(User user) { mongoDb2Template.save(user); } } ``` 这样就可以在DAO层通过`@Qualifier`注解来切换不同的MongoDB连接了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值