MongoDB的shell操作數(shù)據(jù),用到create、read、update、delete操作。
創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比木蘭網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式木蘭網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋木蘭地區(qū)。費(fèi)用合理售后完善,十年實(shí)體公司更值得信賴。1、創(chuàng)建
insert函數(shù)用于創(chuàng)建一個(gè)文檔到集合里面。
例,創(chuàng)建局部變量post,內(nèi)容是代表文檔的JavaScript對(duì)象,里面會(huì)有title、content和date幾個(gè)鍵。
> post = {"title":"My Blog Post",
... "content":"Here's my blog post",
... "date":new Date()}
{
"title" : "My Blog Post",
"content" : "Here's my blog post",
"date" : ISODate("2015-02-02T05:04:55.861Z")
}
> db
test
使用insert方法保存到集合blog中,注意,這時(shí)blog并不存在。
> db.blog.insert(post)
WriteResult({ "nInserted" : 1 })
2、讀取
find()函數(shù)會(huì)讀取集合中的所有文檔:
> db.blog.find();
{ "_id" : ObjectId("54cf05c00eb7b5f5718da826"), "title" : "My Blog Post", "conte
nt" : "Here's my blog post", "date" : ISODate("2015-02-02T05:04:55.861Z") }
若是只想查看一個(gè)文檔,使用findOne()
> db.blog.findone();
2015-02-02T13:10:15.365+0800 TypeError: Property 'findone' of object test.blog i
s not a function
> db.blog.findOne();
{
"_id" : ObjectId("54cf05c00eb7b5f5718da826"),
"title" : "My Blog Post",
"content" : "Here's my blog post",
"date" : ISODate("2015-02-02T05:04:55.861Z")
}
3、更新
3.1
update接受至少兩個(gè)參數(shù):一是更新文檔的限定條件,二是新的文檔。假設(shè)決定給先前寫的文章增加評(píng)論內(nèi)容,則需要增加一個(gè)新的鍵,對(duì)應(yīng)的值是存放評(píng)論的數(shù)組:
修改變量post,增加"comment"鍵:
> post.comments = [];
[ ]
執(zhí)行update
> db.blog.update({"title":"My Blog Post"},post)
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.blog.find();
{ "_id" : ObjectId("54cf05c00eb7b5f5718da826"), "title" : "My Blog Post", "conte
nt" : "Here's my blog post", "date" : ISODate("2015-02-02T05:04:55.861Z"), "comm
ents" : [ ] }
> db.blog.findOne();
{
"_id" : ObjectId("54cf05c00eb7b5f5718da826"),
"title" : "My Blog Post",
"content" : "Here's my blog post",
"date" : ISODate("2015-02-02T05:04:55.861Z"),
"comments" : [ ]
}
3.2使用修改器("$inc"修改器)
通常文檔只會(huì)有一部分要更新,利用原子的更新修改器,可以使得這種部分更新極為高效。更新修改器是種特殊的鍵,用來指定復(fù)雜的更新操作,比如調(diào)整、增加或者刪除鍵,還可能是操作數(shù)組或者內(nèi)嵌文檔。
再看更新一例:
> db.people.find();
{ "_id" : ObjectId("54d08f7f0eb7b5f5718da82a"), "name" : "joe", "age" : 65 }
{ "_id" : ObjectId("54d08fb70eb7b5f5718da82b"), "name" : "joe", "age" : 20 }
{ "_id" : ObjectId("54d08fbd0eb7b5f5718da82c"), "name" : "joe", "age" : 49 }
> db.people.update({"age":20},{"$inc":{"age":1}});
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.people.find();
{ "_id" : ObjectId("54d08a1d0eb7b5f5718da828"), "name" : "joe", "friends" : 32,
"enemies" : 2 }
{ "_id" : ObjectId("54d08f7f0eb7b5f5718da82a"), "name" : "joe", "age" : 65 }
{ "_id" : ObjectId("54d08fb70eb7b5f5718da82b"), "name" : "joe", "age" : 21 }
{ "_id" : ObjectId("54d08fbd0eb7b5f5718da82c"), "name" : "joe", "age" : 49 }
>
4、刪除
remove用來從數(shù)據(jù)庫中永久性地刪除文檔,在不適用參數(shù)進(jìn)行調(diào)用的情況下,它會(huì)刪除一個(gè)集合內(nèi)的所有文檔,也可以接受一個(gè)文檔以指定限制條件:
> db.blog.remove({"title":"My Blog Post"});
WriteResult({ "nRemoved" : 1 })
> db.blog.find();
>
刪除是永久性的,不能撤銷,也不能恢復(fù)。
刪除文檔通常都很快,但是要清除整個(gè)集合,直接刪除集合(然后重建索引)會(huì)更快。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。