node.js mongoose index索引操作
node.js mongoose index索引操作
,感興趣的朋友一起看看吧
簡(jiǎn)介
在 Mongoose 中,索引(Index)是一種用于提高查詢(xún)性能的數(shù)據(jù)結(jié)構(gòu),它可以加速對(duì)數(shù)據(jù)庫(kù)中文檔的檢索操作
索引類(lèi)型
單索引、復(fù)合索引、文本索引、多鍵索引、哈希索引、地理位置空間索引、通配符索引
單索引
在了解索引之前先看一下mongoDb庫(kù),庫(kù)中集合tours有400條數(shù)據(jù),有slug、ratingAverage、price、summary等字段,接下來(lái)就是對(duì)以上四個(gè)字段做索引
我們查詢(xún)slug為the-forest-hiker的文檔,在 MongoDB 中,explain方法用于獲取有關(guān)查詢(xún)執(zhí)行計(jì)劃的詳細(xì)信息,為Query的原型方法,調(diào)用:const queryInfo = await query.explain(),查看執(zhí)行結(jié)果
其中totalDocsExamined為400,表示掃描了400個(gè)文檔,nReturend為1表示匹配并返回文檔的數(shù)量為1。
查詢(xún)一條數(shù)據(jù)就需要把整個(gè)集合全部掃描效率過(guò)于低,當(dāng)文檔個(gè)數(shù)少的情況下可以忽略查詢(xún)速度,如果文檔個(gè)數(shù)數(shù)以萬(wàn)計(jì),那么就要優(yōu)化查詢(xún)速度,所以需要索引。
為slug添加索引,schema.index({ slug: 1 }) (1表示升序,-1表示降序),再查詢(xún)
tourSchema.index({ slug: 1 });
也可在定義schema的時(shí)候設(shè)置文檔字段的schemaType的index為true
此時(shí)totalDocsExamined為1,表示只掃描了1個(gè)文檔,極大的提高了查詢(xún)速度。
當(dāng)執(zhí)行query后,slug_1的Usage為1,表示索引命中了一次。
復(fù)合索引
tourSchema.index({ price: 1, ratingsAverage: -1 });
同時(shí)為兩個(gè)字段添加索引,表示先對(duì)price進(jìn)行升序,然后在同price的情況下進(jìn)行ratingsAverage降序。
查詢(xún)price大于等于1000并且ratingsAverage大于等于4的文檔,查詢(xún)?cè)敿?xì)信息totalDocsExamined為5,nReturend為5,如果不設(shè)置復(fù)合索引,對(duì)兩個(gè)字段進(jìn)行復(fù)合查詢(xún)的時(shí)候,會(huì)對(duì)全文檔進(jìn)行查詢(xún)匹配。
文本索引
tourSchema.index({ summary: 'text' });
const doc = await tourModel.find({ $text: { $search: 'National' }});
查詢(xún)信息
如果不創(chuàng)建索引,則掃描全文檔。
多鍵索引是針對(duì)數(shù)組
- node.js連接mongoose數(shù)據(jù)庫(kù)方法詳解
- node.js使用mongoose操作數(shù)據(jù)庫(kù)實(shí)現(xiàn)購(gòu)物車(chē)的增、刪、改、查功能示例
- node.js利用mongoose獲取mongodb數(shù)據(jù)的格式化問(wèn)題詳解
- Node.js+jade+mongodb+mongoose實(shí)現(xiàn)爬蟲(chóng)分離入庫(kù)與生成靜態(tài)文件的方法
- Node.js中使用mongoose操作mongodb數(shù)據(jù)庫(kù)的方法
- Node.js的MongoDB驅(qū)動(dòng)Mongoose基本使用教程
- 安裝使用Mongoose配合Node.js操作MongoDB的基礎(chǔ)教程
相關(guān)文章
Restify中接入Socket.io報(bào)Error:Can’t set headers的錯(cuò)誤解決
這篇文章主要給大家介紹了在Restify中接入Socket.io報(bào)Error:Can’t set headers的錯(cuò)誤解決方法,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-03-03nodejs密碼加密中生成隨機(jī)數(shù)的實(shí)例代碼
本篇文章主要介紹了nodejs密碼加密中生成隨機(jī)數(shù)的實(shí)例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07Node.JS枚舉統(tǒng)計(jì)當(dāng)前文件夾和子目錄下所有代碼文件行數(shù)
這篇文章主要介紹了Node.JS枚舉統(tǒng)計(jì)當(dāng)前文件夾和子目錄下所有代碼文件行數(shù),本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08Node.js websocket使用socket.io庫(kù)實(shí)現(xiàn)實(shí)時(shí)聊天室
這篇文章主要為大家詳細(xì)介紹了Node.js websocket使用socket.io庫(kù)實(shí)現(xiàn)實(shí)時(shí)聊天室,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02node.js中express中間件body-parser的介紹與用法詳解
這篇文章主要給大家介紹了關(guān)于node.js中express中間件body-parser的相關(guān)資料,文章通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-05-05