關(guān)于MongoTemplate通過id查詢?yōu)閚ull的問題
Mongo的優(yōu)勢
1. 它會(huì)把數(shù)據(jù)文件映射到內(nèi)存中,如果是讀操作,內(nèi)存中的數(shù)據(jù)起到緩存的作用,如果是寫操作,內(nèi)存還可以把隨機(jī)的寫操作轉(zhuǎn)換成順序的寫操作,總之可以大幅度提升性能。MongoDB并不干涉內(nèi)存管理工作,而是把這些工作留給操作系統(tǒng)的虛擬內(nèi)存管理器去處理,這樣做的好處是簡化了MongoDB的工作,但壞處是你沒有方法很方便的控制MongoDB占多大內(nèi)存,幸運(yùn)的是虛擬內(nèi)存管理器的存在讓我們多數(shù)時(shí)候并不需要關(guān)心這個(gè)問題。
2. MongoDB的內(nèi)存使用機(jī)制讓它在緩存重建方面更有優(yōu)勢,簡而言之:如果重啟進(jìn)程,那么緩存依然有效
配置:
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>
錯(cuò)誤實(shí)體類
MongoId設(shè)置為了String,需要設(shè)置為ObjectId類型
@Data @Document("user") public class User { @MongoId private String id; @Field("userName") private String userName; }
正確實(shí)體類
@Data @Document("user") public class User { @MongoId private ObjectId id; @Field("userName") private String userName; }
查詢語句,如果mongoId類型為String那么就查詢不出來,無論是直接使用
findById方法或者find(query)或者id傳ObjectId對(duì)象,都是查不出來的,開始還以為配置錯(cuò)了,結(jié)果是因?yàn)镸ongo的id都是ObjectId無法對(duì)應(yīng)上實(shí)體類中的String類型。改成ObjectId同樣的語句就可以查詢出來了
User user = mongoTemplate.findById(new ObjectId(userId),User.class, "user");
到此這篇關(guān)于關(guān)于MongoTemplate通過id查詢?yōu)閚ull的問題的文章就介紹到這了,更多相關(guān)MongoTemplate查詢?yōu)閚ull內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mongodb eval 執(zhí)行服務(wù)器端腳本
在MongoDB的服務(wù)器端可以通過db.eval函數(shù)來執(zhí)行javascript腳本,如我們可以定義一個(gè)javascript函數(shù),然后通過db.eval在服務(wù)器端來運(yùn)行!我們前面其實(shí)也接觸過在服務(wù)器段運(yùn)行一個(gè)預(yù)定義的javascript腳本的情況,如在$where查詢,執(zhí)行mapreduce任務(wù)等。2015-05-05Mongodb增加、移除Shard Server實(shí)例
這篇文章主要介紹了Mongodb增加、移除Shard Server實(shí)例,shard服務(wù)器(Shard Server).Shard服務(wù)器是存儲(chǔ)實(shí)際數(shù)據(jù)的分片,每個(gè)Shard可以是一個(gè)mongod實(shí)例,也可以是一組mongod實(shí)例構(gòu)成的Replica Sets,需要的朋友可以參考下2015-01-01MongoDB連接和創(chuàng)建數(shù)據(jù)庫的方法講解
這篇文章介紹了MongoDB連接和創(chuàng)建數(shù)據(jù)庫的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-03-03