成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

mongodb 重溫之路 ( 二 )

qianfeng / 3077人閱讀

插入文檔

mongodb 查詢使用 find() 方法。

db.collection.find(query, projection)

* query    可選,使用查詢操作符指定查詢條件
* projection    可選,使用投影操作符指定返回的鍵
 

// 如果想以易讀的方式讀出,使用 `pretty()`
db.col.find().pretty()


// 除了find() 之外還有 findOne() 顧名思義是只找一個(gè)

AND

db.col.find({"title":"zjj" , "sex":"男"})

OR

db.col.find({$or[{key: val1}, {key1: val2}]})

OR 和 AND

db.col.find({"like": {$gt: 50}, $or:[{"by":"zjj"},{"title":"zjjasdada"}]})

條件操作符
一、查詢于投影
1.1 比較運(yùn)算符
$eq
// =
// 查詢 age = 20
db.person.find({ age: { $eq: 20 } })
// 相當(dāng)于
db.person.find({age: 20})
$gt
// >
// 查詢 age > 20
db.person.find({age: {$gt: 20}})
$lt
// <
// 查詢 age < 20
db.person.find({age: {$lt: 20}})
$gte
// >=
// 查詢 age >= 20
db.person.find({age: {$gte: 20}})
$lte
// <=
// 查詢 age <= 20
db.person.find({age: {$lte: 20}})
$ne
// ≠
// 查詢 age ≠ 20
db.person.find({age: {$ne: 20}})
$in
// ≠
// 匹配數(shù)組中的任一值
db.person.find({qyt: {$in :[5, 12]}})
$nin
// nin
// 不匹配數(shù)組中的值
db.person.find({qty : {$nin: [2,322]}})
1.2 邏輯運(yùn)算符
$or
// 或 條件查詢
db.person.find({$or: [{age: {$lt: 20}},{address: "beijing"}]})
$and
// 且 條件查詢
db.person.find({$and: [{age: {$lt: 20}},{address: "beijing"}]})
$not
// 查詢與表達(dá)式不匹配的文檔
db.person.find({age: {$not: {$gt: 20}}});
$nor
// 查詢與任一表達(dá)式都不匹配的文檔
db.col.find({$nor: [{age: 20}, {sex: "男"}]}})
1.3 元素運(yùn)算符
$exists
// 查詢存在指定字段的文檔
// 查詢存在phone字段的文檔:  
db.col.find({phone: {$exists: true}})
$type
// 查詢類型為指定類型的文檔,3.2版本添加alias別名,各種類型的Number及Alias如下

// 假設(shè)有
{ "_id": 1, address: "2030 Martian Way",zipCode: "90698345"},  
{ "_id": 2, address: "156 Lunar Place",zipCode: 43339374},  
{ "_id": 3, address: "2324 Pluto Place",zipCode: NumberLong(3921412)},  
{ "_id": 4, address: "55 Saturn Ring", zipCode: NumberInt(88602117)} 

// 查詢該集合中zipCode字段的數(shù)據(jù)類型為String類型的文檔:
db.col.find({zipCode: {$type: "string"}});
db.addressBook.find( { "zipCode" : { $type : 2 } } );
1.4 元素運(yùn)算符
$mod
// 取余條件查詢
// 查詢age字段的值除以2余0的文檔:  
db.person.find( { age: {$mod : [2, 0] } } )  
$regex
// 正則表達(dá)式查詢 
db.person.find({sku: {   $regex: /^ABC/i  }})
$text
// 文本索引查詢
{  
    $text: {  
        $search: ,  
        $language: ,  
        $caseSensitive: ,  
        $diacriticSensitive:   
    }  
}

// 具體請查看官方文檔
$where
// 可以支持字符穿或者是函數(shù)
db.myCollection.find( { $where: "this.credits == this.debits" } );  
db.myCollection.find( { $where: function() { return obj.credits == obj.debits; } } ); 
1.5 數(shù)組操作符
$all
// 匹配文檔的數(shù)組字段中包含所有指定元素的文檔

查詢articles集合中tags字段(是個(gè)數(shù)組)包含“ssl”和“security”的文檔(包含,但并不是全部等于)  
db.articles.find({tagS: { $all:[ ["aal", "dsada"] ] }  })
$elemMatch()
匹配內(nèi)嵌文檔或數(shù)組中的部分field
// 假設(shè)有
{ _id: 1, results: [ 82, 85, 88 ] }  
{ _id: 2, results: [ 75, 88, 89 ] }  


db.col.find({results: { $elemMatch: { $gte: 80, $lt: 85} }  });
// 查詢r(jià)esults數(shù)組中含有區(qū)間[80,85)元素的文檔(結(jié)果為第一條);
$size
// 匹配數(shù)組長度為指定大小的文檔
查詢已經(jīng)集齊了5張??ǖ奈臋n:  
db.person.find({card:{$size:5}})
1.6投影操作符
$(projection)
//查詢數(shù)組中首個(gè)匹配條件的元素,相當(dāng)于findOne()方法
{ "_id" : 1, "semester" : 1, "grades" : [ 70, 87, 90 ] }  
{ "_id" : 2, "semester" : 1, "grades" : [ 90, 88, 92 ] }  
{ "_id" : 3, "semester" : 1, "grades" : [ 85, 100, 90 ] }  
{ "_id" : 4, "semester" : 2, "grades" : [ 79, 85, 80 ] }  
{ "_id" : 5, "semester" : 2, "grades" : [ 88, 88, 92 ] }  
{ "_id" : 6, "semester" : 2, "grades" : [ 95, 90, 96 ] } 

db.student.find({semester : 1 ,  grades: {$gte: 85}}, {"grades.$": 1});
查詢semester=1,并且grades中符合大于等于85的元素的第一個(gè)元素:

// 查詢結(jié)果是
{ "_id" : 1, "grades" : [ 87 ] }
{ "_id" : 2, "grades" : [ 90 ] }
{ "_id" : 3, "grades" : [ 85 ] }  
$(projection)
{  
 _id: 1,  
 zipcode: "63109",  
 students: [  
              { name: "john", school: 102, age: 10 },  
              { name: "jess", school: 102, age: 11 },  
              { name: "jeff", school: 108, age: 15 }  
           ]  
}  
{  
 _id: 2,  
 zipcode: "63110",  
 students: [  
              { name: "ajax", school: 100, age: 7 },  
              { name: "achilles", school: 100, age: 8 },  
           ]  
}  
{  
 _id: 3,  
 zipcode: "63109",  
 students: [  
              { name: "ajax", school: 100, age: 7 },  
              { name: "achilles", school: 100, age: 8 },  
           ]  
} 
//查詢zipcode為63109并且students數(shù)組中school=102的文檔:

db.school.find({ zipcode: "63109" }, {student: { $elemMatch: { school: 102 } } } )

// result
{ "_id" : 1, "students" : [ { "name" : "john", "school" : 102, "age" : 10 } ] }
{ "_id" : 3 }  
$slice
// 在查詢中將數(shù)組進(jìn)行切片(類似于分頁)
(1)查詢結(jié)果中,對(duì)于comments數(shù)組的元素只顯示前5個(gè):  
db.posts.find( {}, { comments: { $slice: 5 } } )  
(2)查詢結(jié)果中,對(duì)于comments數(shù)組的元素只顯示后5個(gè):  
db.posts.find( {}, { comments: { $slice: -5 } } )  
(3)查詢結(jié)果中,對(duì)于comments數(shù)組的元素跳過(skip)前20個(gè),并只顯示(limit)10個(gè)元素(即21-30):  
db.posts.find( {}, { comments: { $slice: [ 20, 10 ] } } )  
(4)同理,跳過后20個(gè),并顯示10個(gè):  
db.posts.find( {}, { comments: { $slice: [ -20, 10 ] } } )  
skip 和 Limit

limit

// 獲取20條
db.things.find().limit(20);

limit

// 跳過20.再選20條
db.things.find().skip(20).limit(20)
排序
db.things.find().sort({"likes":-1})         -1表示倒序排列

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/19220.html

相關(guān)文章

  • mongode 重溫之路 ( 一 )

    摘要:再次查看刪除數(shù)據(jù)庫刪除當(dāng)前所在的數(shù)據(jù)庫創(chuàng)建集合創(chuàng)建默認(rèn)的集合創(chuàng)建帶有參數(shù)的集合創(chuàng)建集合可以使用下面的方法參數(shù)配置如下字段類型描述布爾如果為,則創(chuàng)建固定集合。布爾可選如為,自動(dòng)在字段創(chuàng)建索引。數(shù)值可選為固定集合指定一個(gè)最大值以字節(jié)計(jì)。 以windows服務(wù)啟動(dòng)mongodb // 創(chuàng)建目錄 d: data/ conf -->配...

    mj 評(píng)論0 收藏0
  • MongoDB ( 四 )高級(jí)_find修飾符

    摘要:返回內(nèi)容查詢出來后顯示的結(jié)果樣式,可以用和控制是否顯示。修飾符文件使用進(jìn)行鏈接對(duì)應(yīng)的集合聲明變量,并把查詢結(jié)果賦值給利用游標(biāo)的進(jìn)行循環(huán)輸出結(jié)果。到此的基礎(chǔ)操作就結(jié)束了,但是我們還沒有結(jié)束呢,下一節(jié)我們會(huì)用配合使用哦 find查詢操作是我們平時(shí)再開發(fā)中最常用的,也是重中之重。 find基本操作符 // 批量插入數(shù)據(jù) var workmate1={ name:JSPang, ag...

    crossea 評(píng)論0 收藏0
  • 【全棧之路】JAVA基礎(chǔ)課程六_集合(20190615v1.0)

    摘要:歡迎進(jìn)入基礎(chǔ)課程博客地址本系列文章將主要針對(duì)一些基礎(chǔ)知識(shí)點(diǎn)進(jìn)行講解,為平時(shí)歸納所總結(jié),不管是剛接觸開發(fā)菜鳥還是業(yè)界資深人士,都希望對(duì)廣大同行帶來一些幫助。是同步的,而不是。因此,更適合于單線程環(huán)境,而適合于多線程環(huán)境。 歡迎進(jìn)入JAVA基礎(chǔ)課程 博客地址:https://blog.csdn.net/houjiyu...本系列文章將主要針對(duì)JAVA一些基礎(chǔ)知識(shí)點(diǎn)進(jìn)行講解,為平時(shí)歸納所總...

    dkzwm 評(píng)論0 收藏0
  • 【全棧之路】JAVA基礎(chǔ)課程六_集合(20190615v1.0)

    摘要:歡迎進(jìn)入基礎(chǔ)課程博客地址本系列文章將主要針對(duì)一些基礎(chǔ)知識(shí)點(diǎn)進(jìn)行講解,為平時(shí)歸納所總結(jié),不管是剛接觸開發(fā)菜鳥還是業(yè)界資深人士,都希望對(duì)廣大同行帶來一些幫助。是同步的,而不是。因此,更適合于單線程環(huán)境,而適合于多線程環(huán)境。 歡迎進(jìn)入JAVA基礎(chǔ)課程 博客地址:https://blog.csdn.net/houjiyu...本系列文章將主要針對(duì)JAVA一些基礎(chǔ)知識(shí)點(diǎn)進(jìn)行講解,為平時(shí)歸納所總...

    tain335 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<