MongoDB中的增刪改操作

MongoDB的增刪改查:

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序定制開發(fā)、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了廬陽免費建站歡迎大家使用!

注意:"_id"這個字段是數(shù)據(jù)庫默認給我們加的GUID,目的是保證數(shù)據(jù)的唯一性

1、添加insert

1、語法:db.集合.insert({"key1":value1,"key2":value2,....."keyN":valueN})

> db.wqq.insert({"name":"wqq",age:25,height:1.65,dep:"DEGREE"})

WriteResult({ "nInserted" : 1 })

##插入可以指定_id的值,以及其他,值之間的嵌套

for(i=1;i<100;i++)db.wqq.insert({"_id":i,age:22+i,name:"aaa"+i})

db.集合.save({"key1":value1,"key2":value2,....."keyN":valueN}) //save()如果已經(jīng)存在就不會插入,如果不存在就會插入(指的是_id的值)

db.wqq.save({"_id":19,"age":41,"name":"aaa19"})

WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 0 })

> db.wqq.save({"_id":119,"age":41,"name":"aaa19"})

WriteResult({ "nMatched" : 0, "nUpserted" : 1, "nModified" : 0, "_id" : 119 })

2、插入多條:

   db.abc.insert([{name:"wangwu",age:22,sex:1,class:"jsj"},{name:"aaa",age:22,sex:1,class:"bdd"}])

2、查找find

  1、全部查找:db.集合.find()

  2、條件查找:db.集合.find({"key1":value1,"key2":value2,....."keyN":valueN})

  3、其他統(tǒng)計

db.wqq.count() <===>db.wqq.find().count()  //統(tǒng)計

db.wqq.find().sort({name:-1})              //排序 -1為降序 1為升序

db.wqq.find().limit(4) //取多少個

db.wqq.find().limit(4).pretty()   //格式化顯示

db.wqq.find().skip(4).limit(10) //跳過幾個取值

db.wqq.find().skip(4).limit(10).sort({"_id":-1})  //通過排序值來取幾個值

db.wqq.find({"age":{$all:[110]}})

db.wqq.find({"age":{$in:[110,111,112....]}})      //返回數(shù)組里存在的值

db.wqq.find({"age":{$nin:[110,111,112....]}})      //返回數(shù)組里存在的值

db.wqq.find({"age":{$exists:1}}) //檢查一個字段是否存在

db.wqq.find({"age":{$mod:[10,2]}})//返回字段取模后的等于余數(shù)的值

db.wqq.find({$or:[{"age":40},{"name":"aaa19"}]})//查看指定多個條件的記錄,跟SQL的OR差不多

db.wqq.find({$nor:[{"age":40},{"name":"aaa19"}]})//與or相反

##比較運算符

$gt:大于   $gte:大于等于     $lt :小于   $lte :小于等于   $ne :不等于

db.wqq.find({"age":{$lt:100}})

##邏輯運算

與運算:

db.wqq.find({age:23,name:"aaa1"})

或($in)/非 $nin

db.wqq.find({age:{$in:[11,222,33,444]}})

##正則匹配

db.wqq.find({name:/aaa/})

##$where

// 返回含有l(wèi)ogin_name字段的文檔

db.getCollection('users').find({$where:function(){

return !!this.login_name;

      }})

## and 操作

db.wqq.find({name:"wangwu",class:"jsj"})

##組合查詢

db.abc.find({name:{$exists:1,$nin:["張三"]}})   //字段存在且不是叫"張三"

3、更新update()

1、更新某字段:

db.wqq.update({age:42},{$set:{name:"sbt"}})

2、給某文檔增加值或者不存在則增加字段值

db.wqq.update({name:"aaa78"},{$inc:{age:2}},0,1)

3、批量更新,若字段存在更新,若字段不存在增加字段

db.wqq.update({name:"aaa"},{$set:{age:2}},false,true)

db.wqq.update({name:"張三"},{$set:{age:3}},0,1)

4、一個集合只有一個key-value的更新

db.wqq.update({name:"張三"},{name:"嗎詠倫"})

4、刪除

    1、刪除某些文檔

db.wqq.remove({"name":"abc"})

2、刪除整個集合:

db.wqq.drop()

3、刪除第幾條

db.wqq.remove({name:"abc"},2)

4、刪除字段

db.abc.update({},{$unset:{age:50}},0,1)  //刪除多個字段,不加0,1 刪除第一條的字段

5、游標(biāo)的使用

 var x=db.wqq.find();

 x.next()

 x.hasNext()

 while(x.hasNext()==true){x.next()} 

6、在集合里增加數(shù)組、彈出

 db.abc.update({},{$push:{arr:3}})  //增加一個值得數(shù)組

 db.abc.update({},{$pushAll:{arr:[1,2,3,4,5,6,7,8,9]}})  //增加多個值得數(shù)組

 db.abc.update({},{$pop:{arr:1}})    //彈出數(shù)組的最后一個值,-1為數(shù)組的第一個值

 db.abc.update({name:"張三"},{$pull:{arr:4}},0,1)     //刪除數(shù)組的指定的值

 db.abc.update({},{$addToSet:{arr:6}},0,1)    //向數(shù)組添加數(shù)組,若存在則不重復(fù)添加

 db.abc.update({name:"張三"},{$addToSet:{email2:{$each:[1,2,3,4]}}},0,1)   //用來運行修改器向集合多次操作數(shù)據(jù)

新聞名稱:MongoDB中的增刪改操作
瀏覽路徑:http://muchs.cn/article44/jepsee.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供服務(wù)器托管云服務(wù)器、、網(wǎng)頁設(shè)計公司、靜態(tài)網(wǎng)站自適應(yīng)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都app開發(fā)公司