关于MongoTemplate通过id查询为null的问题
Mongo的优势
1. 它会把数据文件映射到内存中,如果是读操作,内存中的数据起到缓存的作用,如果是写操作,内存还可以把随机的写操作转换成顺序的写操作,总之可以大幅度提升性能。MongoDB并不干涉内存管理工作,而是把这些工作留给操作系统的虚拟内存管理器去处理,这样做的好处是简化了MongoDB的工作,但坏处是你没有方法很方便的控制MongoDB占多大内存,幸运的是虚拟内存管理器的存在让我们多数时候并不需要关心这个问题。
2. MongoDB的内存使用机制让它在缓存重建方面更有优势,简而言之:如果重启进程,那么缓存依然有效
配置:
spring.data.mongodb.uri=mongodb://test:123456@${ipAddr}:27017/mrqc?connectTimeoutMS=10000&authSource=admin
版本:
<dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-mongodb</artifactId> <version>2.2.0.RELEASE</version> </dependency>
错误实体类
MongoId设置为了String,需要设置为ObjectId类型
@Data
@Document("user")
public class User {
@MongoId
private String id;
@Field("userName")
private String userName;
}
正确实体类
@Data
@Document("user")
public class User {
@MongoId
private ObjectId id;
@Field("userName")
private String userName;
}
查询语句,如果mongoId类型为String那么就查询不出来,无论是直接使用
findById方法或者find(query)或者id传ObjectId对象,都是查不出来的,开始还以为配置错了,结果是因为Mongo的id都是ObjectId无法对应上实体类中的String类型。改成ObjectId同样的语句就可以查询出来了
User user = mongoTemplate.findById(new ObjectId(userId),User.class, "user");
到此这篇关于关于MongoTemplate通过id查询为null的问题的文章就介绍到这了,更多相关MongoTemplate查询为null内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Mongodb UPDATE使用$sort将数组重新排序的示例代码
$sort方法在$push操作过程中,修改数组元素的排序,$sort方法,必须和$each共同使用,mongodb允许用户传递一个空的数组给$each方法,保证用户无须向数组中插入元素也可以将数组进行排序,本文给大家介绍了Mongodb UPDATE使用$sort将数组重新排序,需要的朋友可以参考下2024-06-06
使用aggregate在MongoDB中查询重复数据记录的方法
这篇文章主要介绍了使用aggregate在MongoDB中查询重复数据记录的方法的相关资料,需要的朋友可以参考下2016-01-01
解决mongodb在ubuntu下启动失败,提示couldn‘t remove fs lock errno:9 Bad
之前MongoDB启动的时候是蛮正常的,不知道后来启动报错了,就把粘贴出来查询了。经过一番百度,才找的处理的办法,分享给大家2014-08-08


最新评论