MongoDB學(xué)習(xí)

簡介:

有c++語言編寫,可為web應(yīng)用提供可擴(kuò)展的高性能能數(shù)據(jù)存儲记劈。
介于關(guān)系型數(shù)據(jù)庫與非關(guān)系型數(shù)據(jù)庫之間挪蹭,是非關(guān)系型數(shù)據(jù)庫當(dāng)中功能最豐富的。
支持的數(shù)據(jù)結(jié)構(gòu)松散咐扭,類似json的bson格式,即可存儲比較復(fù)雜的數(shù)據(jù)類型滑废。


特性:
特性
1 基于分布式文件存儲的開源數(shù)據(jù)系統(tǒng)
2 可為web應(yīng)用提供可擴(kuò)展高性能的數(shù)據(jù)存儲方案
3 將數(shù)據(jù)存儲為一個文檔蝗肪,文檔類似與jason格式

MongoDB結(jié)構(gòu):
MongoDB 關(guān)系型數(shù)據(jù)庫
數(shù)據(jù)庫(database) 數(shù)據(jù)庫(database)
集合(collection) 表(table)
文檔(document) 行(row)

基本操作:

進(jìn)入mongodb數(shù)據(jù)庫:mongo
退出mongodb數(shù)據(jù)庫:exit

#進(jìn)入mongodb數(shù)據(jù)庫
Jayss@localhost:~$ mongo
MongoDB shell version: 2.6.10
connecting to: test
Server has startup warnings:
2019-02-03T23:43:03.529+0800 [initandlisten]
2019-02-03T23:43:03.529+0800 [initandlisten] ** NOTE: This is a 32 bit MongoDB binary.
2019-02-03T23:43:03.529+0800 [initandlisten] **       32 bit builds are limited to less than 2GB of data (or less with --journal).
2019-02-03T23:43:03.529+0800 [initandlisten] **       See http://dochub.mongodb.org/core/32bit
2019-02-03T23:43:03.529+0800 [initandlisten]

#退出mongodb數(shù)據(jù)庫
> exit
bye


庫級操作

#顯示所有數(shù)據(jù)庫

> show dbs
admin              (empty)
local              0.078GB
python_foundation  0.078GB
test               0.078GB

#---------------------
#查看當(dāng)前所在庫

> db
test

#---------------------
#切換/創(chuàng)建數(shù)據(jù)庫:use 數(shù)據(jù)庫名  (當(dāng)數(shù)據(jù)庫名不存在時,則自動創(chuàng)建該數(shù)據(jù)庫)

> use local                 #切換local數(shù)據(jù)庫
switched to db local
> db                        #顯示當(dāng)前數(shù)據(jù)庫
local
> use study                #創(chuàng)建study數(shù)據(jù)庫
switched to db study
> db
study
> show dbs                 #此時查看不到study數(shù)據(jù)庫的原因是study數(shù)據(jù)庫中無數(shù)據(jù)
admin              (empty)
local              0.078GB
python_foundation  0.078GB
test               0.078GB

#---------------------
#刪除庫:db.dropDatabase()

> show dbs                        #顯示所有數(shù)據(jù)庫
admin              (empty)
local              0.078GB
python_foundation  0.078GB
study              0.078GB
test               0.078GB
> use study                       #切換到study數(shù)據(jù)庫
switched to db study
> db.dropDatabase()               #刪除當(dāng)前所在的數(shù)據(jù)庫
{ "dropped" : "study", "ok" : 1 }
> show dbs                        #顯示當(dāng)前所有的數(shù)據(jù)庫(可看到study數(shù)據(jù)庫已被刪除)
admin              (empty)
local              0.078GB
python_foundation  0.078GB
test               0.078GB


集合操作


#查看當(dāng)前數(shù)據(jù)庫的集合:show collections

> use python_foundation            #切換python_foundation數(shù)據(jù)庫
switched to db python_foundation
> db                              #顯示當(dāng)前所在數(shù)據(jù)庫
python_foundation
> show collections                #顯示當(dāng)前所載數(shù)據(jù)庫的集合
student
system.indexes

#---------------------
#創(chuàng)建集合:db.createCollection(集合名)

> db.createCollection('user1')        #創(chuàng)建名叫name的集合
{ "ok" : 1 }
> show collections                   #查看當(dāng)前數(shù)據(jù)庫所有集合
user1
system.indexes

#---------------------
#刪除集合

> show collections          #查看當(dāng)前數(shù)據(jù)庫所有集合
name
student
system.indexes
> db.name.drop()            #刪除名叫name的集合
true
> show collections          #查看當(dāng)前數(shù)據(jù)庫所有集合
student
system.indexes


文檔操作

即添加文檔(數(shù)據(jù))

#查看集合中全部文檔:db.集合名.find()

> db.user1.find()
{ "_id" : ObjectId("5c62c1292ee6afdfb9c69779"), "name" : "jayss" }

#---------------------
#添加數(shù)據(jù):db.集合名.insert({數(shù)據(jù)})

> db.user1.insert({'name':'jayss'})          #為user1集合添加文檔
WriteResult({ "nInserted" : 1 })
> db.study.find()                             #查看user1集合的所有文檔
{ "_id" : ObjectId("5c62ad6a2ee6afdfb9c69775"), "name" : "jayss" }

#添加多條文檔
> db.user1.insert([
... {'age':20},
... {'sex':'male'}])
BulkWriteResult({
        "writeErrors" : [ ],
        "writeConcernErrors" : [ ],
        "nInserted" : 2,
        "nUpserted" : 0,
        "nMatched" : 0,
        "nModified" : 0,
        "nRemoved" : 0,
        "upserted" : [ ]
})

#查看集合user1的所有文檔
> db.user1.find()
{ "_id" : ObjectId("5c62c1292ee6afdfb9c69779"), "name" : "jayss" }
{ "_id" : ObjectId("5c62c2b977f12d5b7ee5fec9"), "age" : 20 }
{ "_id" : ObjectId("5c62c2b977f12d5b7ee5feca"), "sex" : "male" }

#---------------------
#修改一條數(shù)據(jù):db.集合名.update({舊數(shù)據(jù)},{$set:{新數(shù)據(jù)}})

> db.user1.find()
{ "_id" : ObjectId("5c62c1292ee6afdfb9c69779"), "name" : "jayss" }
{ "_id" : ObjectId("5c62c2b977f12d5b7ee5fec9"), "age" : 20 }
{ "_id" : ObjectId("5c62c2b977f12d5b7ee5feca"), "sex" : "male" }

> db.user1.update({'age':20},{$set:{'age':21}})                        #把集合user1里的age等于20修改為21
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

> db.user1.find()
{ "_id" : ObjectId("5c62c1292ee6afdfb9c69779"), "name" : "jayss" }
{ "_id" : ObjectId("5c62c2b977f12d5b7ee5fec9"), "age" : 21 }
{ "_id" : ObjectId("5c62c2b977f12d5b7ee5feca"), "sex" : "male" }


#---------------------
#格式化顯示:db.集合名.find().pretty()

> db.user1.find().pretty()
{ "_id" : ObjectId("5c62ad6a2ee6afdfb9c69775"), "name" : "jayss" }
{ "_id" : ObjectId("5c62bc992ee6afdfb9c69776"), "age" : 20 }
{ "_id" : ObjectId("5c62bc992ee6afdfb9c69777"), "sex" : "male" }


#---------------------
#查看滿足條件的數(shù)據(jù):db.集合名.find({數(shù)據(jù)})

> db.user1.find({'name':'jayss'})
{ "_id" : ObjectId("5c62ad6a2ee6afdfb9c69775"), "name" : "jayss" }

#---------------------
#刪除集合中滿足條件的文檔

> db.user1.remove({'sex':'male'})          #刪除sex數(shù)據(jù)
WriteResult({ "nRemoved" : 1 })
> db.user1.find()
{ "_id" : ObjectId("5c62c1292ee6afdfb9c69779"), "name" : "jayss" }
{ "_id" : ObjectId("5c62c2b977f12d5b7ee5fec9"), "age" : 21 }

#---------------------
#刪除集合中所有文檔:db.集合名.remove()

> db.user1.remove()


歡迎技術(shù)交流

WeChat......

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蠕趁,一起剝皮案震驚了整個濱河市薛闪,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌俺陋,老刑警劉巖豁延,帶你破解...
    沈念sama閱讀 218,204評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件怀各,死亡現(xiàn)場離奇詭異,居然都是意外死亡术浪,警方通過查閱死者的電腦和手機(jī)瓢对,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來胰苏,“玉大人硕蛹,你說我怎么就攤上這事∷恫ⅲ” “怎么了法焰?”我有些...
    開封第一講書人閱讀 164,548評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長倔毙。 經(jīng)常有香客問我埃仪,道長,這世上最難降的妖魔是什么陕赃? 我笑而不...
    開封第一講書人閱讀 58,657評論 1 293
  • 正文 為了忘掉前任卵蛉,我火速辦了婚禮,結(jié)果婚禮上么库,老公的妹妹穿的比我還像新娘傻丝。我一直安慰自己,他們只是感情好诉儒,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,689評論 6 392
  • 文/花漫 我一把揭開白布葡缰。 她就那樣靜靜地躺著,像睡著了一般忱反。 火紅的嫁衣襯著肌膚如雪泛释。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,554評論 1 305
  • 那天温算,我揣著相機(jī)與錄音怜校,去河邊找鬼。 笑死米者,一個胖子當(dāng)著我的面吹牛韭畸,可吹牛的內(nèi)容都是我干的宇智。 我是一名探鬼主播蔓搞,決...
    沈念sama閱讀 40,302評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼随橘!你這毒婦竟也來了喂分?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,216評論 0 276
  • 序言:老撾萬榮一對情侶失蹤机蔗,失蹤者是張志新(化名)和其女友劉穎蒲祈,沒想到半個月后甘萧,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,661評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡梆掸,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,851評論 3 336
  • 正文 我和宋清朗相戀三年扬卷,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片酸钦。...
    茶點(diǎn)故事閱讀 39,977評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡怪得,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出卑硫,到底是詐尸還是另有隱情徒恋,我是刑警寧澤,帶...
    沈念sama閱讀 35,697評論 5 347
  • 正文 年R本政府宣布欢伏,位于F島的核電站入挣,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏硝拧。R本人自食惡果不足惜径筏,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,306評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望障陶。 院中可真熱鬧匠璧,春花似錦、人聲如沸咸这。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,898評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽媳维。三九已至酿雪,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間侄刽,已是汗流浹背指黎。 一陣腳步聲響...
    開封第一講書人閱讀 33,019評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留州丹,地道東北人醋安。 一個月前我還...
    沈念sama閱讀 48,138評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像墓毒,于是被迫代替她去往敵國和親吓揪。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,927評論 2 355

推薦閱讀更多精彩內(nèi)容