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

首頁 > 數據庫 > MongoDB > 正文

MongoDB的基礎查詢和索引操作方法總結

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

查詢操作

1、查詢所有記錄

db.userInfo.find();

相當于:

select* from userInfo;

2、查詢去掉后的當前聚集集合中的某列的重復數據

db.userInfo.distinct("name");

會過濾掉name中的相同數據

相當于:

select disttince name from userInfo;

3、查詢age = 22的記錄

db.userInfo.find({"age": 22});

相當于:

select * from userInfo where age = 22;

4、查詢age > 22的記錄

db.userInfo.find({age: {$gt: 22}});

相當于:

select * from userInfo where age >22;

5、查詢age < 22的記錄

db.userInfo.find({age: {$lt: 22}});

相當于:

select * from userInfo where age <22;

6、查詢age >= 25的記錄

db.userInfo.find({age: {$gte: 25}});

相當于:

select * from userInfo where age >= 25;

7、查詢age <= 25的記錄

db.userInfo.find({age: {$lte: 25}});

相當于:

select * from userInfo where age <= 25;

8、查詢age >= 23 并且 age <= 26

db.userInfo.find({age: {$gte: 23, $lte: 26}});

相當于:

select * from userInfo where age >=23 and age <= 26;

9、查詢name中包含 mongo的數據

db.userInfo.find({name: /mongo/});

相當于:

select * from userInfo where name like ‘%mongo%';

10、查詢name中以mongo開頭的

db.userInfo.find({name: /^mongo/});

相當于:

select * from userInfo where name like ‘mongo%';

11、查詢指定列name、age數據

db.userInfo.find({}, {name: 1, age: 1});

相當于:

select name, age from userInfo;

當然name也可以用true或false,當用ture的情況下河name:1效果一樣,如果用false就是排除name,顯示name以外的列信息。

12、查詢指定列name、age數據, age > 25

db.userInfo.find({age: {$gt: 25}}, {name: 1, age: 1});

相當于:

select name, age from userInfo where age >25;

13、按照年齡排序

升序:

db.userInfo.find().sort({age: 1});

降序:

db.userInfo.find().sort({age: -1});

14、查詢前5條數據

db.userInfo.find().limit(5);

相當于:

select * from (select * from userInfo) where rownum < 6;//oracleselect * from userInfo limit 5;//mysql

15、查詢10條以后的數據

db.userInfo.find().skip(10);

相當于:

select * from userInfo where id not in (select id from (select * from userInfo) where  and rownum < 11);

16、查詢在5-10之間的數據
db.userInfo.find().limit(10).skip(5);

可用于分頁,limit是pageSize,skip是第幾頁*pageSize

17、or與 查詢

db.userInfo.find({$or: [{age: 22}, {age: 25}]});

相當于:

select * from userInfo where age = 22 or age = 25;

18、查詢第一條數據

db.userInfo.findOne();db.userInfo.find().limit(1);

相當于:

select * from (select * from userInfo) where and rownum < 2

19、查詢某個結果集的記錄條數

db.userInfo.find({age: {$gte: 25}}).count();相當于:select count(*) from userInfo where age >= 20;


索引

1、創建索引

db.userInfo.ensureIndex({username: 1});

在MongoDB中,我們同樣可以創建復合索引,如下:

db.userInfo.ensureIndex({username: 1, age: -1});

該索引被創建后,基于username和age的查詢將會用到該索引,或者是基于username的查詢也會用到該索引,但是只是基于age的查詢將不會用到該復合索引。因此可以說,如果想用到復合索引,必須在查詢條件中包含復合索引中的前N個索引列。然而如果查詢條件中的鍵值順序和復合索引中的創建順序不一致的話,MongoDB可以智能的幫助我們調整該順序,以便使復合索引可以為查詢所用。如:

db.test.find({"age": 30, "username": "stephen"})

對于上面示例中的查詢條件,MongoDB在檢索之前將會動態的調整查詢條件文檔的順序,以使該查詢可以用到剛剛創建的復合索引。

2、創建唯一索引

在缺省情況下創建的索引均不是唯一索引。下面的示例將創建唯一索引,如:

db.test.ensureIndex({"userid":1},{"unique":true})

如果再次插入userid重復的文檔時,MongoDB將報錯,以提示插入重復鍵,如:

db.test.insert({"userid":5})db.test.insert({"userid":5})
E11000 duplicate key error index: test.test.$userid_1 dup key: { : 5.0 }

如果插入的文檔中不包含userid鍵,那么該文檔中該鍵的值為null,如果多次插入類似的文檔,MongoDB將會報出同樣的錯誤,如:

db.test.insert({"userid1":5})db.test.insert({"userid1":5})
E11000 duplicate key error index: test.test.$userid_1 dup key: { : null }

如果在創建唯一索引時已經存在了重復項,我們可以通過下面的命令幫助我們在創建唯一索引時消除重復文檔,僅保留發現的第一個文檔,如:

--先刪除剛剛創建的唯一索引。

db.test.dropIndex({"userid":1})

--插入測試數據,以保證集合中有重復鍵存在。

db.test.remove()db.test.insert({"userid":5})db.test.insert({"userid":5})

--創建唯一索引,并消除重復數據。

db.test.ensureIndex({"userid":1},{"unique":true,"dropDups":true})

--查詢結果確認,重復的鍵確實在創建索引時已經被刪除。

db.test.find(){ "_id" : ObjectId("4fe823c180144abd15acd52e"), "userid" : 5 }

我們同樣可以創建復合唯一索引,即保證復合鍵值唯一即可。如:

db.test.ensureIndex({"userid":1,"age":1},{"unique":true})

3、查詢當前聚集集合所有索引

db.userInfo.getIndexes();

4、查看總索引記錄大小

db.userInfo.totalIndexSize();

5、讀取當前集合的所有index信息

db.users.reIndex();

6、刪除指定索引

db.users.dropIndex("username":1);

7、刪除所有索引索引

db.users.dropIndexes();


注:相關教程知識閱讀請移步到MongoDB頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
热re91久久精品国99热蜜臀| 欧美日韩在线视频观看| 日韩中文字幕在线免费观看| 中文字幕日韩精品在线| 精品国偷自产在线| 国产欧美一区二区三区在线看| 一区二区欧美久久| 久久综合伊人77777| 成人av在线亚洲| 日韩**中文字幕毛片| 亚洲国产精品热久久| 亚洲国产又黄又爽女人高潮的| 欧美午夜影院在线视频| 亚洲国产精品一区二区久| 成人午夜在线影院| 国产精品99免视看9| 国产福利视频一区| 亚洲xxxxx性| 亚洲free嫩bbb| 亚洲香蕉成人av网站在线观看| 亚洲精品久久久久久久久久久久久| 亚洲人成在线观看网站高清| 国产中文日韩欧美| 日韩视频在线一区| 国产精品一区二区三区成人| 色婷婷**av毛片一区| 日韩资源在线观看| 亚洲精品wwwww| 亚洲男人的天堂在线| 91精品国产99久久久久久| 欧美一级淫片aaaaaaa视频| 亚洲影院色无极综合| 国产精品专区h在线观看| 欧美午夜片在线免费观看| 精品性高朝久久久久久久| 亚洲精品国产美女| 综合久久五月天| 亚洲综合社区网| 亚洲欧洲自拍偷拍| 欧美成人免费网| 亚洲欧洲第一视频| 91精品国产高清久久久久久| 国产精品va在线播放我和闺蜜| 精品在线小视频| 欧美性生交大片免网| 国产精品久久久久久久午夜| 久色乳综合思思在线视频| 久久久亚洲国产天美传媒修理工| 亚洲色无码播放| 日韩中文字幕网站| 欧美激情va永久在线播放| 国产一区二区三区网站| 精品无人国产偷自产在线| 精品日韩视频在线观看| 日韩激情视频在线| 日韩人在线观看| 国产亚洲欧美视频| 97av在线视频| 国产亚洲欧美一区| 日韩欧美中文字幕在线观看| 3344国产精品免费看| 亚洲激情自拍图| 人人澡人人澡人人看欧美| 亚洲精品电影网| 国产成人一区二区| 97在线免费观看视频| 日本一区二区不卡| 欧美激情va永久在线播放| 91热福利电影| 国产精品欧美一区二区三区奶水| 欧美成人黑人xx视频免费观看| 国产视频久久久久| 亚洲成人免费在线视频| 狠狠躁夜夜躁人人爽天天天天97| 伦伦影院午夜日韩欧美限制| 欧美中文字幕在线视频| 日韩av中文字幕在线播放| 日韩av片永久免费网站| 欧美资源在线观看| 97在线精品视频| 国产日韩中文字幕在线| 亚洲精品网站在线播放gif| 亚洲天堂第二页| 性亚洲最疯狂xxxx高清| 欧美大片欧美激情性色a∨久久| 在线播放日韩av| 26uuu亚洲伊人春色| 亚洲精品美女在线观看播放| 国产xxx69麻豆国语对白| 亚洲精品aⅴ中文字幕乱码| 亚洲人成77777在线观看网| 国产欧美一区二区三区四区| 欧美精品激情在线观看| 98视频在线噜噜噜国产| 欧美一区在线直播| 精品视频在线播放免| 久久久电影免费观看完整版| 欧美精品亚州精品| 亚洲精品丝袜日韩| 一区二区三区www| 日韩欧美综合在线视频| 另类天堂视频在线观看| 成人午夜一级二级三级| 91丨九色丨国产在线| 欧美性生活大片免费观看网址| 国产999精品久久久| 久久久精品国产| 黑人巨大精品欧美一区二区免费| 国产精品十八以下禁看| 国产日韩欧美中文| 欧美男插女视频| 亚洲色图在线观看| 91欧美激情另类亚洲| 久久久久国色av免费观看性色| 欧美成人免费大片| 神马久久久久久| 欧美日韩免费一区| 久久亚洲国产精品成人av秋霞| 不卡av电影在线观看| 91国产精品电影| 超碰91人人草人人干| 一区二区三区视频观看| 91精品国产91久久久久久最新| 亚洲综合最新在线| 久久韩国免费视频| 国产精品亚洲欧美导航| 亚洲伊人久久综合| 热久久这里只有| 91系列在线播放| 国产精品18久久久久久首页狼| 亚洲国产精品资源| 亚洲视频电影图片偷拍一区| 久久琪琪电影院| 亚洲人在线观看| 91夜夜未满十八勿入爽爽影院| 国产女人精品视频| 亚洲精品女av网站| 国产精品久久久久久久久粉嫩av| 亚洲大胆人体在线| 中日韩午夜理伦电影免费| 国外成人在线播放| 中文字幕日本精品| 国产丝袜精品第一页| 日韩av免费看| 国产成人精品一区二区在线| 97久久精品在线| 亚洲一区二区三区在线免费观看| 久久精品视频网站| 亚洲免费一级电影| 成人国内精品久久久久一区| 欧美日韩亚洲天堂| 日韩精品视频在线免费观看| 国产精品自拍偷拍视频| 91久久精品在线| 亚洲社区在线观看| 欧美成人精品在线观看| 91久久精品在线| 日本精品免费一区二区三区| 综合国产在线视频| 亚洲日韩欧美视频| 亚洲成人av在线播放| 97涩涩爰在线观看亚洲| 91视频88av| 亚洲欧美国内爽妇网|