人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動態(tài)

mongoDB數(shù)據(jù)庫索引快速入門指南

發(fā)布日期:2022-07-15 19:57 | 文章來源:源碼之家

MongoDB 索引

索引通常能夠極大的提高查詢的效率,如果沒有索引,MongoDB在讀取數(shù)據(jù)時必須掃描集合中的每個文件并選取那些符合查詢條件的記錄。

這種掃描全集合的查詢效率是非常低的,特別在處理大量的數(shù)據(jù)時,查詢可以要花費幾十秒甚至幾分鐘,這對網(wǎng)站的性能是非常致命的。

索引是特殊的數(shù)據(jù)結(jié)構(gòu),索引存儲在一個易于遍歷讀取的數(shù)據(jù)集合中,索引是對數(shù)據(jù)庫表中一列或多列的值進(jìn)行排序的一種結(jié)構(gòu)。

mongo可以通過創(chuàng)建索引來提高查詢的速度。

1. 開始與準(zhǔn)備數(shù)據(jù)

啟動mongo并選擇目標(biāo)數(shù)據(jù)庫

mongo

use test

然后準(zhǔn)備一組數(shù)據(jù)(10萬條數(shù)據(jù),較大的數(shù)據(jù)量)

for(i=0;i<100000;i++){db.test.insert({name:'test'+i,age:i})}

2. 創(chuàng)建索引前

查詢一下name為"test90000"的數(shù)據(jù)。并使用explain方法來查看查詢的性能。

db.test1.find({name:"test90000"}).explain('executionStats')

這里可以看到查詢花了53毫秒

3. 創(chuàng)建索引 createIndex

給字段name創(chuàng)建索引

db.test1.createIndex({name: 1})

查看索引:

給name創(chuàng)建索引之前,_id字段默認(rèn)為索引,創(chuàng)建后集合有兩個索引,"_id"和"name"。

4. 創(chuàng)建索引后

再次查找該條數(shù)據(jù),并查看查詢的性能,發(fā)現(xiàn)所用時間接近0毫秒。即設(shè)定索引后查詢性能大大提升了。

db.test1.find({name:"test90000"}).explain('executionStats')

5. 刪除索引

db.test1.dropIndex({name:1})

查看之

db.test1.getIndexes()

如圖,只剩下了"_id"一個索引。"name"索引已被刪除。

6.唯一索引與符合索引

①唯一索引

db.test1.createIndex({name: 1},{"unique":true})

查看索引

db.test1.getIndexes()

可以看到,unique為true。

設(shè)定為唯一索引后,該索引的值不能重復(fù)。
(這個特點也可以用于寫爬蟲時不想要某字段的重復(fù)數(shù)據(jù)時,達(dá)到去重的目的。)

如圖插入一條name重復(fù)的數(shù)據(jù)時,會產(chǎn)生如下報錯:

即插入失敗了。

②復(fù)合索引

創(chuàng)建多個索引的方式被稱為復(fù)合索引。

首先刪掉剛剛創(chuàng)建的索引name

db.test1.dropIndex({name:1})

然后一次創(chuàng)建name,age兩個索引

db.test1.createIndex({'name':1,'age':1})

處理海量數(shù)據(jù)時,在一定的規(guī)則下使用復(fù)合索引,可以大幅提升查詢的性能.

到此這篇關(guān)于mongoDB數(shù)據(jù)庫索引快速入門指南的文章就介紹到這了,更多相關(guān)mongoDB索引內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!

香港穩(wěn)定服務(wù)器

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部