激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

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

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

服務(wù)器之家 - 數(shù)據(jù)庫 - MongoDB - MongoDB查詢之高級操作詳解(多條件查詢、正則匹配查詢等)

MongoDB查詢之高級操作詳解(多條件查詢、正則匹配查詢等)

2020-12-19 22:02w田翔 MongoDB

這篇文章主要給大家介紹了關(guān)于MongoDB查詢之高級操作(多條件查詢、正則匹配查詢等)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)

MongoDB查詢之高級操作

語法介紹

MongoDB查詢文檔使用find()方法,同時find()方法以非結(jié)構(gòu)化的方式來顯示所有查詢到的文檔。

?
1
2
3
4
5
6
7
8
9
10
-- 1.基本語法
db.collection.find(query, projection) -- 返回所有符合查詢條件的文檔
db.collection.findOne(query, projection) -- 返回第一個符合查詢條件的文檔
-- query:可選,查詢條件操作符,用于指定查詢條件
-- projection:可選,投影操作符,用來指定需要返回的鍵(默認(rèn)省略)
-- 例1:查詢users集合中年齡為18的所有文檔
db.users.find({age: 18})
 
-- 2.如果需要以易讀的方式來觀察數(shù)據(jù),可以使用pretty()方法
db.collection.find(query, projection).pretty()

AND 條件與 OR 條件

MongoDB的find()方法可以傳入多個鍵,每個鍵以逗號隔開,這樣即可起到SQL的AND條件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
-- 1.AND條件基本語法
db.collection.find({key1:value1, key2:value2})
-- 例1:查詢users集合中年齡為18的女生的所有文檔
db.users.find({age: 18, sex: 'girl'})
 
-- 2.OR條件基本語法
db.collection.find({
 $or: [
 {key1: value1},
 {key2:value2}
 ]
})
-- 例2:查詢users集合中年齡為18或性別為女生的所有文檔
db.users.find({
 $or: [
 {age: 18},
 {sex: 'girl'}
 ]
})

條件操作符

條件操作符用處理條件關(guān)系以從MongoDB中查詢符合條件的文檔數(shù)據(jù),條件操作符如下:

  • 大于:$gt
  • 小于:$lt
  • 大于等于:$gte
  • 小于等于:$lte
?
1
2
3
4
5
6
7
8
-- 查詢users集合中年齡大于18歲的文檔數(shù)據(jù)
db.users.find({age : {$gt : 18}})
-- 查詢users集合中年齡小于18歲的文檔數(shù)據(jù)
db.users.find({age : {$lt : 18}})
-- 查詢users集合中年齡大于等于18歲的文檔數(shù)據(jù)
db.users.find({age : {$gte : 18}})
-- 查詢users集合中年齡大于等于18歲的文檔數(shù)據(jù)
db.users.find({age : {$lte : 18}})

$type操作符

$type操作符是基于BSON類型來檢索集合中匹配的數(shù)據(jù)類型,MongoDB中可以使用查詢的數(shù)據(jù)類型如下表:

 

類型 $type代表數(shù)字 說明
Double 1 64位浮點數(shù)
String 2 字符串類型
Object 3 對象類型
Array 4 數(shù)組類型
Binary Data 5 二進(jìn)制數(shù)據(jù)類型
Objectid 7 對象id類型
Boolean 8 布爾類型
Date 9 日期類型
Null 10 用于表示空值或不存在的字段
Regular Expression 11 正則表達(dá)式類型
JavaScript 13 JavaScript代碼
JavaScript (with scope) 15 帶作用域的JavaScript代碼
32-bit integer 16 32位整數(shù)
Timestamp 17 時間戳類型
64-bit integer 18 64位整數(shù)
Min key -1 最小鍵
Max key 127 最大鍵

 

下面我將使用$type,作為查詢條件舉例說明:

?
1
2
-- 例:查詢users集合中,姓名為字符串類型的文檔
db.users.find({"name" : {$type : 2}})

查詢中使用limit()、skip()、sort()方法

  1. limit()方法指根據(jù)查詢條件讀取指定數(shù)量的文檔數(shù)據(jù)記錄。
  2. skip()方法指跳過指定數(shù)量的文檔數(shù)據(jù),從其后按照查詢條件查詢。
  3. sort()方法指將查詢到的文檔數(shù)據(jù)按照指定字段進(jìn)行升序或降序排序,字段值為1指升序,字段值為-1指降序。
  4. 下面我將使用limit()與skip()方法舉例說明。
?
1
2
3
4
5
6
7
8
-- 使用語法(limit()、skip()、sort()方法可以組合使用)
db.collectionName.find().limit(NUMBER)
db.collectionName.find().skip(NUMBER)
db.collectionName.find().sort({"key": 1/-1})
-- 例1:跳過前50條數(shù)據(jù)查詢users集合中姓名字段為字符串類型的100之內(nèi)的數(shù)據(jù)
db.users.find({"name" : {$type : 2}}).limit(100).skip(50)
-- 例2:將查詢到users集合中姓名字段為字符串類型的文檔數(shù)據(jù)按升序排列
db.users.find({"name" : {$type : 2}}).sort({"name": 1})

查詢中使用正則表達(dá)式

這里先介紹一下正則表達(dá)式:正則表達(dá)式是使用單個字符串來描述、匹配一系列符合某個句法規(guī)則的字符串。

MongoDB中使用$regex操作符來設(shè)置匹配字符串的正則表達(dá)式語言。

?
1
2
3
4
5
-- 使用語法
db.collectionName.find({key:{ $regex: regex, $options: options }})
-- 例:不區(qū)分大小寫查詢users集合中姓名包含web的文檔數(shù)據(jù)(以下兩種方式查詢結(jié)果相同)
db.users.find({ "name" : { $regex : "web", $options: "i" } })
db.users.find({ "name" : /web/i } })

總結(jié)

到此這篇關(guān)于MongoDB查詢之高級操作(多條件查詢、正則匹配查詢等)的文章就介紹到這了,更多相關(guān)MongoDB多條件查詢、正則匹配查詢內(nèi)容請搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!

原文鏈接:https://segmentfault.com/a/1190000037451303

延伸 · 閱讀

精彩推薦
  • MongoDBmongodb基本命令實例小結(jié)

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

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

    dawn-liu3652020-05-26
  • MongoDB遷移sqlserver數(shù)據(jù)到MongoDb的方法

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

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

    聽楓xl9682021-01-03
  • MongoDBMongoDB 內(nèi)存使用情況分析

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

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

    MongoDB教程網(wǎng)10002020-09-29
  • MongoDBMongoDB中javascript腳本編程簡介和入門實例

    MongoDB中javascript腳本編程簡介和入門實例

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

    MongoDB教程網(wǎng)6982020-04-24
  • MongoDBMongodb實現(xiàn)定時備份與恢復(fù)的方法教程

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

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

    chenjsh364522020-05-13
  • MongoDBMongoDB安裝圖文教程

    MongoDB安裝圖文教程

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

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

    分布式文檔存儲數(shù)據(jù)庫之MongoDB分片集群的問題

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

    Linux-18743072020-12-20
  • MongoDBMongoDB憑什么躋身數(shù)據(jù)庫排行前五

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

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

    孫浩峰3892020-05-22
主站蜘蛛池模板: 久久国产精品久久久久久电车 | 亚洲一区二区三区在线免费观看 | 高清做爰免费无遮网站挡 | 久久精品亚洲欧美日韩精品中文字幕 | 成人午夜毛片 | 中文在线日韩 | 欧美一区二区三区成人精品 | 亚洲欧美日韩精品久久亚洲区色播 | 精品999久久久 | 国产一国产一级毛片视频在线 | 国产精品久久久久久久久久东京 | 日韩毛片一区二区三区 | 一本色道久久综合亚洲精品图片 | 欧美专区视频 | 性高跟鞋xxxxhd4kvideos | 蜜桃视频在线免费播放 | 欧美成人鲁丝片在线观看 | 成人av一二三区 | 视频一区二区视频 | 全免费午夜一级毛片真人 | 国产一区二区不卡视频 | 在线亚州 | 深夜福利视频绿巨人视频在线观看 | 亚洲国产成人一区 | 538在线精品 | 狠狠操夜夜爱 | 伦理三区| 99亚洲伊人久久精品影院红桃 | 污黄视频在线播放 | 在线播放黄色网址 | 精品国产一区二区三区久久久蜜 | 日日摸夜夜添夜夜添牛牛 | 日本一区二区三区四区高清视频 | 国产亚洲精品久久久久久久久 | 国产91九色视频 | 久久久久久久黄色片 | 久久久久久久不卡 | 深夜视频福利 | 日本一区二区精品视频 | 国产精品免费成人 | 色诱亚洲精品久久久久久 |