MongoDB之解决spring data mongodb使用Example无法查询到MongoDB中的数据问题

1.给springboot配置默认打印sql执行

application.properties里面加入

logging.level.org.springframework.data.mongodb.core= DEBUG

2.使用可视化工具先执行我们想使用的测试用例

这是一个简单的模糊匹配!!
在这里插入图片描述

3.运行代码,查看日志

在这里插入图片描述
发现混入了一个很奇怪的_class字段,解决办法忽略该字段。

原因是在Spring Data中使用MongoDB时,插入数据会添加一个_class字段,_class这个字段是用来映射POJO的。
在这里插入图片描述
再给查询的实体类其他的值也赋值,发现只要是实体类的属性有值都会去默认匹配,需要我们把这些字段忽略
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值