亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MongoDB > 正文

十天掌握MongoDB之四:使用索引

2020-03-14 13:23:21
字體:
來源:轉載
供稿:網友

創建索引

MongoDB的索引機制與傳統的關系型數據庫索引幾乎是一樣的,絕大多數優化SQL索引的技巧也都適用于MongoDB。索引會增加數據插入、更新和刪除的性能開銷,應避免為每個鍵都創建索引。

// 創建 索引

db . things . ensureIndex ({

'j ' : 1

});

// 創建子文檔 索引

db . things . ensureIndex ({

'user.Name ' : - 1

});

// 創建復合索引

db . things . ensureIndex ({

'j ' : 1 , // 升序

'x ' : - 1 // 降序

});

/*

如果您的 find 操作只用到了一個鍵,那么索引方向是無關緊要的;當創建復合索引的時候,一定要謹慎斟酌每個鍵的排序方向 。

* /

修改索引

// 修改索引,只需要重新運行索引命令即可

// 如果索引已經存在則會重建, 不存在的索引會被 添加

db . things . ensureIndex ({

// 原來的索引會 重建

'user.Name ' : - 1 ,

// 新增一個升序 索引

'user.Name ' : 1 ,

// 為 Age 新建降序 索引

'user.Age ' : - 1

}, {

// 打開后臺執行

‘background' : true

});

// 重建索引

db. things .reIndex();

注意:MongoDB不會檢查要索引的鍵名是否真的存在。當background為false或未指定時,創建索引的過程會以阻塞的形式運行,此時MongoDB無法處理任何請求。

刪除索引

如果刪除整個集合(drop)也會刪除集合中的索引。如果是刪除集合中所有的文檔(remove)則不會影響索引,當有新文檔插入時,索引就會重建。

// 刪除集合中的所有 索引

db . things . dropIndexes ();

// 刪除指定鍵的索引

db . things . dropIndex ({

x : 1 ,

y : - 1

});

// 使用 command 刪除指定鍵的 索引

db . runCommand ({

dropIndexes : 'foo ' ,

index : { y : 1 }

});

// 使用 command 刪除所有 索引

db . runCommand ({

dropIndexes : 'foo ' ,

index : '*‘

});

唯一索引

// 創建唯一索引,同時這也是一個符合唯一索引

db . things . ensureIndex (

{

'firstName ' : 1 ,

'lastName ' : 1

}, {

// 指定為唯一索引

'unique ' : true ,

// 刪除重復 記錄

'dropDups ' : true

});

注意:

1、_id本身就是個唯一索引,不同的是,它不能被刪除;

2、刪除重復記錄時,僅會按順序保留第一文檔;

3、如果創建了唯一索引,但文檔并不包含該鍵,默認以null存儲,因此如果發現了第二項未指定該鍵或該鍵被指定為null的記錄,就會被認為是重復的;

4、所謂復合唯一索引,允許單鍵重復,但組合起來之后是不允許重復的;

地理空間索引 - 創建

不了解神馬是地理空間?先看下百度的解釋吧【地理空間】!

MongoDB為處理地理空間信息增加了一個專門的索引結構——2d,對就是二弟!

要使用二弟索引,表示地理坐標的鍵必須是一個長度為2的數組。然后為該鍵創建取值為“2d”的索引即可。請看下面代碼實例。

// 文檔 格式

{

'_ id' : 1 ,

'name ' : ' 天安門 ' ,

'location' :[

116.12345 ,

39.54321

]

}

// 創建地理空間 索引

db . map . ensureIndex ({

'location ' : '2d‘

});

MongoDB的地理空間索引的取值沒有單位,這意味著你可以為其設置任何單位。默認地理空間索引的假設值是-180 ~ 180。如果需要自定義其他的取值范圍,請參考下面代碼實例。

// 創建地理空間 索引

db . map . ensureIndex ({

'location ' : '2d‘

}, {

'min ' : - 10000 ,

'max ' : 10000

});

地理空間索引 - $NEAR

$near操作符與geoNear Command的區別在于:geoNear會同時返回每個地標與給定中心點的距離(注意,這里的距離沒有單位)。

// $near 操作符

db . places . find ({

loc : {

// 中心點

$ near : [ 50 , 50 ],

// 查詢半徑

$ maxDistance : 5

}

}). limit ( 20 );

// 如果沒有指定 limit ,其默認值為 100

地理空間索引 - $WITHIN(BOX)

$within操作符支持以下幾個選項:

• $box:矩形查找

• $center:圓形查找

• $polygon:多邊形查找(v1.9+支持)

$box實例

// 定義一個矩形 區域

var box = [

// 左 上角

[ 40.73083 , - 73.99756 ],

// 右 下角

[ 40.741404 , - 73.988135 ]

];

// 查找

db . places . find ({

" loc" : {

"$ within" : {

"$ box" : box

}

}

});

$center實例

// 定義 中心點

var center = [ 50 , 50 ];

// 定義查找 半徑

var radius = 10 ;

// 查找

db . places . find ({

" loc" : {

"$ within" : {

// 注意這里是數組傳遞

"$ center" : [

center ,

radius

]

}

}

});

$polygon實例

十天掌握MongoDB之四:使用索引

小結

1、索引可以加速查詢;

2、單個索引無需在意其索引方向;

3、多鍵索引需要慎重考慮每個索引的方向;

4、做海量數據更新時應當先卸載所有索引,待數據更新完成后再重建索引;

5、不要試圖為每個鍵都創建索引,應考慮實際需要,并不是索引越多越好;

6、唯一索引可以用來消除重復記錄;

7、地理空間索引是沒有單位的,其內部實現是基本的勾股定理算法。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美黄色片免费观看| 日韩av色在线| www国产精品视频| 色偷偷9999www| 久久人人爽人人爽人人片av高请| 国产成人啪精品视频免费网| 久久精品成人欧美大片古装| 亚洲字幕在线观看| 孩xxxx性bbbb欧美| 亚洲成人av片| 国产mv久久久| 国产自产女人91一区在线观看| 亚洲区一区二区| 欧美激情手机在线视频| 亚洲成人黄色在线观看| 中国人与牲禽动交精品| 国产精品色悠悠| 日韩免费不卡av| 一区二区三区精品99久久| 色系列之999| 成人久久精品视频| 社区色欧美激情 | 青青草99啪国产免费| 97在线免费观看视频| 91av网站在线播放| 成人黄色片网站| 国产精品视频区1| 亚洲精美色品网站| 91精品一区二区| 久久免费少妇高潮久久精品99| 欧美大尺度在线观看| 国产精品高潮呻吟久久av无限| 6080yy精品一区二区三区| 欧美人成在线视频| 精品自在线视频| 色爱av美腿丝袜综合粉嫩av| 国产一区二区动漫| 97国产精品视频人人做人人爱| 在线观看欧美日韩| 亚洲国产精品成人一区二区| 欧美性色xo影院| 欧美性xxxxx| 亚洲天堂av图片| 国产视频久久久久| 久久影院在线观看| 亚洲女人被黑人巨大进入al| 欧美精品久久久久久久免费观看| 国产97在线亚洲| 国产免费一区二区三区在线能观看| 国产欧美精品一区二区| 亚洲美腿欧美激情另类| 色先锋久久影院av| 91牛牛免费视频| 国产亚洲欧美日韩精品| 欲色天天网综合久久| 成人综合国产精品| 久久久久国产精品免费网站| 超碰精品一区二区三区乱码| 欧美精品第一页在线播放| 国产精品三级在线| 国产日韩欧美电影在线观看| 成人在线小视频| 亚洲电影成人av99爱色| 国产亚洲精品一区二555| 久久久亚洲天堂| 国产精品久久久久久影视| 91精品国产亚洲| 这里只有精品丝袜| 久久噜噜噜精品国产亚洲综合| 亚洲视频在线视频| 欧美另类暴力丝袜| 国产精品久久久久久久美男| 久久久精品在线| 成人国产精品免费视频| 欧美日韩在线影院| 国产精品白丝jk喷水视频一区| 91免费国产网站| 国产精品亚发布| 国产日韩欧美在线| 另类少妇人与禽zozz0性伦| 日韩一区二区精品视频| 欧美色另类天堂2015| 这里只有视频精品| 日韩三级影视基地| 久久综合久久88| 2019中文字幕全在线观看| 欧美色欧美亚洲高清在线视频| 日韩国产精品视频| 成人h视频在线观看播放| 国产精品爽爽ⅴa在线观看| 亚洲美女喷白浆| 国模精品视频一区二区| 午夜精品在线视频| 国产精品美女www爽爽爽视频| 亚洲自拍在线观看| 日日摸夜夜添一区| 亚洲aⅴ男人的天堂在线观看| 亚洲乱码国产乱码精品精天堂| 九九久久久久久久久激情| 性色av一区二区咪爱| 久久久久久久激情视频| 狠狠躁夜夜躁人人躁婷婷91| 精品一区二区三区四区| 国产精品偷伦视频免费观看国产| 超碰精品一区二区三区乱码| 欧美激情videoshd| 国产日韩中文字幕在线| 欧美精品免费在线观看| 国内精品久久久久伊人av| 国产99久久精品一区二区永久免费| 久久福利视频网| 亚洲欧美一区二区三区四区| 亚洲色图日韩av| 欧美在线观看一区二区三区| 欧美人交a欧美精品| 欧美在线免费看| 久久视频在线观看免费| 国产精品9999| 欧洲日本亚洲国产区| 91美女片黄在线观| 欧美理论电影网| 国产精品久久久久久av| 在线亚洲男人天堂| 全球成人中文在线| 91久久精品国产91久久性色| 成人精品一区二区三区电影黑人| 亚洲成人中文字幕| 精品成人久久av| 九九精品视频在线| 欧美激情xxxx| 久久久亚洲影院| 精品久久久久久久久久久久| 在线视频欧美性高潮| 国产成人一区二区三区电影| 精品亚洲一区二区三区在线观看| 国产成人精品免费久久久久| 欧美激情视频一区二区三区不卡| 久久精品视频中文字幕| 日韩精品视频在线观看网址| 91精品国产777在线观看| 91在线观看免费网站| 一夜七次郎国产精品亚洲| 亚洲最新av在线网站| 亚洲娇小xxxx欧美娇小| 国产91热爆ts人妖在线| 亚洲日本aⅴ片在线观看香蕉| 欧美日韩福利电影| 夜夜嗨av色综合久久久综合网| 韩剧1988免费观看全集| 国产精品久久久久一区二区| 久久天天躁夜夜躁狠狠躁2022| 国产精品一区二区性色av| 最近免费中文字幕视频2019| 福利二区91精品bt7086| 91av中文字幕| 亚洲mm色国产网站| 亚洲精品小视频| 亚洲欧美日韩国产中文专区| 亚洲男人第一av网站| 亚洲国产日韩欧美综合久久| 欧美在线观看一区二区三区| 欧美国产日韩一区二区三区| 日韩欧美国产骚| 亚洲第一区中文99精品|