mongo使用筆記

1.本地啓動mongo /usr/local/mongodb/bin/mongod –dbpath=/usr/local/mongodb/data/db/
2.導出 #mongodump -h 127.0.0.1 -o /home/zhangxiaojing/
3.mongo導出庫 # /usr/local/mongodb/bin/mongodump -h 127.0.0.1 -d zhao_manage(指定數據庫) -o(導出所有表/集合) /home/zhangxiaojing/(導出位置)
4.還原導出的數據表mongoimport -d tank -c users –upsert /zhagnxiaojing
導出mongo數據表:
5.mongoexport -h IP –port 端口 -u 用戶名 -p 密碼 -d 數據庫 -c 表名 -f 字段 -q 條件導出 –csv -o 文件名

mongoexport -d zhao_manage -c department_id -f id,name –type=csv -o /home/zhangxiaojing/department_id.csv

1.連接:mongo 127.0.0.1:8003
2.使用:show dbs
use admin
use tables 切換數據庫
3. mongodb_修改器($inc/$set/$unset/$push/$pop/upsert……)
對於文檔的更新除替換外,針對某個或多個文檔只需要部分更新可使用原子的更新修改器,能夠高效的進行文檔更新。更新修改器是種特殊的鍵,用來指定複雜的操作,比如增加、刪除或者調整鍵,還可能是操作數組或者內嵌文檔。
1.$inc
得出結論:修改器$inc可以對文檔的某個值爲數字型(只能爲滿足要求的數字)的鍵進行增減的操作。
(這裏有個問題:更新默認只對滿足條件的記錄集中第一個文檔進行更新,那麼使用$inc修改器之後,還是一樣嗎?)
2.$set
用來指定一個鍵並更新鍵值,若鍵不存在並創建,可改變鍵的值類型,對於內嵌文檔在使用$set更新時,使用”.”連接的方式

db.c.update({"name":"toyota"},{"$set":{"size.width":7}})
        "name":"toyota",
        "type" : "suv",
        "size" : {
                "height" : 8,
                "width" : 7,
                "length" : 15
        }

3.$unset
從字面就可以看出其意義,主要是用來刪除鍵。
得出結論:使用修改器$unset時,不論對目標鍵使用1、0、-1或者具體的字符串等都是可以刪除該目標鍵。

db.a.update({"uid" : "20120002","type" : "3"},{"$unset":{"desc":"sssssss"}})

4.數組修改器–$push
得出結論:$push–向文檔的某個數組類型的鍵添加一個數組元素,不過濾重複的數據。添加時鍵存在,要求鍵值類型必須是數組;鍵不存在,則創建數組類型的鍵。
–先push一個當前文檔中不存在的鍵title

> db.c.update({"name" : "toyota"},{$push:{"title":"t1"}})
> db.c.find()
{ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8,
 "width" : 7, "length" : 15 }, "title" : [ "t1" ], "type" : "suv" }

–再向title中push一個值

> db.c.update({"name" : "toyota"},{$push:{"title":"t2"}})
> db.c.find()
{ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8,
 "width" : 7, "length" : 15 }, "title" : [ "t1", "t2", "t2" ], "type" : "suv" }

–再向一個已經存在的鍵值非數組類型的鍵push一個值

> db.c.update({"name" : "toyota"},{$push:{"size.height":10}})
Cannot apply $push/$pushAll modifier to non-array
> db.c.update({"name" : "toyota"},{$push:{"name":"ddddddd"}})

Cannot apply $push/$pushAll modifier to non-array
得出結論:$push–向文檔的某個數組類型的鍵添加一個數組元素,不過濾重複的數據。添加時鍵存在,要求鍵值類型必須是數組;鍵不存在,則創建數組類型的鍵
5.數組修改器–$ne/$addToSet主要給數組類型鍵值添加一個元素時,避免在數組中產生重複數據,$ne在有些情況是不通行的
6.數組修改器–$pop、$pull``$pop從數組的頭或者尾刪除數組中的元素
–從數組的尾部刪除 0

> db.c.update({"name" : "toyota"},{$pop:{"title":0}})
> db.c.find()
{ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8,
 "width" : 7, "length" : 15 }, "title" : [ "t2" ], "type" : "suv" }

$pull從數組中刪除滿足條件的元素

> db.c.update({"name" : "toyota"},{$pull:{"title":"t2"}})
> db.c.find()
{ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8,
 "width" : 7, "length" : 15 }, "title" : [ "t1", "t3" ], "type" : "suv" }

7.數組的定位修改器
在需要對數組中的值進行操作的時候,可通過位置或者定位操作符(”$”).數組是0開始的,可以直接將下標作爲鍵來選擇元素。

{"uid":"001",comments:[{"name":"t1","size":10},{"name":"t2","size":12}]}
> db.c.find({"uid":"001"})
{ "_id" : ObjectId("5003da405af21ff428dafbe8"), "uid" : "001", "comments" : [ {
"name" : "t1", "size" : 10 }, { "name" : "t2", "size" : 12 } ] }
> db.c.update({"uid":"001"},{$inc:{"comments.0.size":1}})
> db.c.find({"uid":"001"})
{ "_id" : ObjectId("5003da405af21ff428dafbe8"), "uid" : "001", "comments" : [ {
"name" : "t1", "size" : 11 }, { "name" : "t2", "size" : 12 } ] }
> db.c.update({"comments.name":"t1"},{$set:{"comments.$.size":1}})
> db.c.find({"uid":"001"})
{ "_id" : ObjectId("5003da405af21ff428dafbe8"), "uid" : "001", "comments" : [ {
"name" : "t1", "size" : 1 }, { "name" : "t2", "size" : 12 } ] }

–若爲多個文檔滿足條件,則只更新第一個文檔。
8.upsert
upsert是一種特殊的更新。當沒有符合條件的文檔,就以這個條件和更新文檔爲基礎創建一個新的文檔,如果找到匹配的文檔就正常的更新。
使用upsert,既可以避免競態問題,也可以減少代碼量(update的第三個參數就表示這個upsert,參數爲true時)

> db.c.remove()
> db.c.update({"size":11},{$inc:{"size":3}})
> db.c.find()
> db.c.update({"size":11},{$inc:{"size":3}},false)
> db.c.find()
> db.c.update({"size":11},{$inc:{"size":3}},true)
> db.c.find()
{ "_id" : ObjectId("5003ded6c28f67507a6df1de"), "size" : 14 }

9.save函數
1.可以在文檔不存在的時候插入,存在的時候更新,只有一個參數文檔。
2.要是文檔含有”_id”,會調用upsert。否則,會調用插入。

> db.a.find()
{ "_id" : ObjectId("50026affdeb4fa8d154f8572"), "desc" : "hello world1!", "num": 50,
 "sname" : "jk", "type" : "1", "uid" : "20120002" }
> var o = db.a.findOne()
> o.num = 55
55
> db.a.save(o)
> db.a.find()
{ "_id" : ObjectId("50026affdeb4fa8d154f8572"), "desc" : "hello world1!", "num": 55,
 "sname" : "jk", "type" : "1", "uid" : "20120002" }

1.要插入文件,也可以使用 db.post.save(document)。 如果不指定_id在文檔中,然後將其 save() 方法和 insert()方法工作一樣。如果指定_id,它會替換整個數據文件,其中包含_id 指定save()方法。
2.pretty() 方法
結果顯示在一個格式化的方式,可以使用 pretty() 方法.

>db.mycol.find().pretty()

3.AND 在MongoDB中用法

>db.mycol.find({key1:value1, key2:value2}).pretty();

4.MongoDB中OR

db.mycol.find(
   {
      $or: [
         {key1: value1}, {key2:value2}
      ]
   }
).pretty()

5.ensureIndex() 方法
要創建一個索引,需要使用MongoDB 的ensureIndex()方法。

語法:
ensureIndex() 方法的基本語法如下

>db.COLLECTION_NAME.ensureIndex({KEY:1})

這裏關鍵是要在其中創建索引,1是按升序排列的字段名稱。要創建降序索引,需要使用-1。
6.sort() 方法
要在 MongoDB 中的文檔進行排序,需要使用sort()方法。 sort() 方法接受一個文檔,其中包含的字段列表連同他們的排序順序。要指定排序順序1和-1。 1用於升序排列,而-1用於降序。

語法:
sort() 方法的基本語法如下

>db.COLLECTION_NAME.find().sort({KEY:1})
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章