一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫(kù)技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫(kù) - MongoDB - MongoDB下根據(jù)數(shù)組大小進(jìn)行查詢的方法

MongoDB下根據(jù)數(shù)組大小進(jìn)行查詢的方法

2020-04-24 15:37MongoDB教程網(wǎng) MongoDB

這篇文章主要介紹了MongoDB下根據(jù)數(shù)組大小進(jìn)行查詢的方法,分別實(shí)現(xiàn)了指定大小的數(shù)組和某個(gè)范圍的數(shù)組,需要的朋友可以參考下

注意:作者使用的mongodb版本為2.4.7。

首先插入測(cè)試數(shù)據(jù)

復(fù)制代碼 代碼如下:

db.data.insert({name:'a', num:[12,123,22,34,1]});
db.data.insert({name:'b', num:[42,22]});
db.data.insert({name:'c', num:[49]});

 

鍵num對(duì)應(yīng)的值是數(shù)組。

查詢num的數(shù)組值具有指定大小的document

最好的方法是使用$size,例如指定大小為2,可以:

復(fù)制代碼 代碼如下:
db.data.find({num:{$size:2}})


不過(guò)$size有一個(gè)缺陷,就是無(wú)法查詢某個(gè)范圍的大小,例如下面的語(yǔ)句是無(wú)法按照預(yù)期運(yùn)行的:

復(fù)制代碼 代碼如下:
db.data.find({num:{$size:{$gt:2}}}); //錯(cuò)誤


官方文檔中建議,如果需要查詢的數(shù)組大小在某個(gè)范圍,可以另外為每個(gè)文檔添加一個(gè)鍵來(lái)保存當(dāng)前數(shù)組的大小。

 

如果數(shù)組大小是某個(gè)范圍

另外兩種思路,第一個(gè)思路是使用$where,例如如果要求數(shù)組大小小于3:

復(fù)制代碼 代碼如下:
db.data.find({ $where: "this.num.length < 3" })


這種方法具有很大的靈活性,但是速度會(huì)慢一些。

 

關(guān)于$where,請(qǐng)參考官方文檔:http://docs.mongodb.org/manual/reference/operator/query/where/。

另外一個(gè)比較高效的方法是判斷數(shù)組中的某個(gè)指定索引的元素是否存在,例如如果要求數(shù)組大小小于3:

復(fù)制代碼 代碼如下:
db.data.find({ "num.2": {$exists:0} })


數(shù)組大小小于3,就意味著num[2]不存在。

 

如果要求數(shù)組大小大于3,可以:

復(fù)制代碼 代碼如下:
db.data.find({ "num.3": {$exists:1} })

 

 

延伸 · 閱讀

精彩推薦
  • MongoDBMongoDB 內(nèi)存使用情況分析

    MongoDB 內(nèi)存使用情況分析

    都說(shuō) MongoDB 是個(gè)內(nèi)存大戶,但是怎么知道它到底用了多少內(nèi)存呢...

    MongoDB教程網(wǎng)10002020-09-29
  • MongoDBMongoDB安裝圖文教程

    MongoDB安裝圖文教程

    這篇文章主要為大家詳細(xì)介紹了MongoDB安裝圖文教程,分為兩大部分為大家介紹下載MongoDB和安裝MongoDB的方法,感興趣的小伙伴們可以參考一下 ...

    Yangyi.He6132020-05-07
  • MongoDB分布式文檔存儲(chǔ)數(shù)據(jù)庫(kù)之MongoDB分片集群的問(wèn)題

    分布式文檔存儲(chǔ)數(shù)據(jù)庫(kù)之MongoDB分片集群的問(wèn)題

    這篇文章主要介紹了分布式文檔存儲(chǔ)數(shù)據(jù)庫(kù)之MongoDB分片集群的問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋...

    Linux-18743072020-12-20
  • MongoDB遷移sqlserver數(shù)據(jù)到MongoDb的方法

    遷移sqlserver數(shù)據(jù)到MongoDb的方法

    這篇文章主要介紹了遷移sqlserver數(shù)據(jù)到MongoDb的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下...

    聽(tīng)楓xl9682021-01-03
  • MongoDBMongodb實(shí)現(xiàn)定時(shí)備份與恢復(fù)的方法教程

    Mongodb實(shí)現(xiàn)定時(shí)備份與恢復(fù)的方法教程

    這篇文章主要給大家介紹了Mongodb實(shí)現(xiàn)定時(shí)備份與恢復(fù)的方法教程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面...

    chenjsh364522020-05-13
  • MongoDBMongoDB中javascript腳本編程簡(jiǎn)介和入門(mén)實(shí)例

    MongoDB中javascript腳本編程簡(jiǎn)介和入門(mén)實(shí)例

    作為一個(gè)數(shù)據(jù)庫(kù),MongoDB有一個(gè)很大的優(yōu)勢(shì)——它使用js管理數(shù)據(jù)庫(kù),所以也能夠使用js腳本進(jìn)行復(fù)雜的管理——這種方法非常靈活 ...

    MongoDB教程網(wǎng)6982020-04-24
  • MongoDBMongoDB憑什么躋身數(shù)據(jù)庫(kù)排行前五

    MongoDB憑什么躋身數(shù)據(jù)庫(kù)排行前五

    MongoDB以比去年同期超出65.96分的成績(jī)繼續(xù)雄踞榜單前五,這個(gè)增幅在全榜僅次于PostgreSQL的77.99,而其相對(duì)于4月份的6.10分的增長(zhǎng)也是僅次于微軟SQL Server排名...

    孫浩峰3892020-05-22
  • MongoDBmongodb基本命令實(shí)例小結(jié)

    mongodb基本命令實(shí)例小結(jié)

    這篇文章主要介紹了mongodb基本命令,結(jié)合實(shí)例形式總結(jié)分析了MongoDB數(shù)據(jù)庫(kù)切換、查看、刪除、查詢等基本命令用法與操作注意事項(xiàng),需要的朋友可以參考下...

    dawn-liu3652020-05-26
主站蜘蛛池模板: 极品美女a∨片在线看 | 午夜精品久久久久久 | 亚洲 欧美 国产 日韩 字幕 | 国产麻豆流白浆在线观看 | 亚洲一二三区久久五月天婷婷 | 亚洲国产区 | 男人猛进猛出女人下面视频 | 波多野结衣 在线播放 | 日本特黄一级午夜剧场毛片 | 性欧美sexvideo另类 | 99久久国产综合精麻豆 | 天堂素人在线 | 继攵催眠女乱h调教 | 亚洲国产精品久久卡一 | 国产精品资源在线观看网站 | 丰满大乳欲妇三级k8 | 无码人妻丰满熟妇啪啪网不卡 | 国产精品手机视频一区二区 | 午夜黄视频 | 亚洲国产区中文在线观看 | 日本aaaaa高清免费看 | 青草视频网址 | 九九热在线观看视频 | 2022国产在线观看 | 久热这里只有精品99国产6 | 日本一区二区视频在线 | 亚洲AV午夜福利精品香蕉麻豆 | 亚洲成人影院在线 | 歪歪漫画a漫入口 | 小辣椒精品福利视频导航 | 奇米9999| 男人天堂久久 | 国产a高清 | 亚洲精品国产国语 | 国产一卡二卡3卡4卡四卡在线视频 | 激情视频网址 | 扒开斗罗美女了的胸罩和内裤漫画 | 按摩院已婚妇女中文字幕 | h视频免费高清在线观看 | 日产乱码卡一卡2卡三卡四福利 | 国产成人精品日本亚洲网址 |