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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)