本文實(shí)例講述了MongoDB數(shù)據(jù)庫(kù)安裝配置、基本操作。分享給大家供大家參考,具體如下:
NO SQL:NoSQL(NoSQL = Not Only SQL ),意即"不僅僅是SQL",是對(duì)不同于傳統(tǒng)的關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng)(RDBMS)的統(tǒng)稱。NoSQL用于超大規(guī)模數(shù)據(jù)的存儲(chǔ),這些類型的數(shù)據(jù)存儲(chǔ)不需要固定的模式,無(wú)需多余操作就可以橫向擴(kuò)展。
| RDBMS | NOSQL |
| - 高度組織化結(jié)構(gòu)化數(shù)據(jù) - 結(jié)構(gòu)化查詢語(yǔ)言(SQL) - 數(shù)據(jù)和關(guān)系都存儲(chǔ)在單獨(dú)的表中。 - 數(shù)據(jù)操縱語(yǔ)言,數(shù)據(jù)定義語(yǔ)言 - 嚴(yán)格的一致性 - 基礎(chǔ)事務(wù) | - 代表著不僅僅是SQL - 沒有聲明性查詢語(yǔ)言 - 沒有預(yù)定義的模式 -鍵 - 值對(duì)存儲(chǔ),列存儲(chǔ),文檔存儲(chǔ) - 最終一致性,而非ACID屬性 - 非結(jié)構(gòu)化和不可預(yù)知的數(shù)據(jù) - CAP定理 - 高性能,高可用性和可伸縮性 |
MongoDB 是由C++語(yǔ)言編寫的,是一個(gè)基于分布式文件存儲(chǔ)的開源數(shù)據(jù)庫(kù)系統(tǒng)。MongoDB 將數(shù)據(jù)存儲(chǔ)為一個(gè)文檔,數(shù)據(jù)結(jié)構(gòu)由鍵值對(duì)(key=>value)組成。MongoDB 文檔類似于 JSON 對(duì)象,可輕易查詢文檔中內(nèi)嵌的對(duì)象及數(shù)組。字段值可以包含其他文檔,數(shù)組及文檔數(shù)組??梢酝ㄟ^本地或者網(wǎng)絡(luò)創(chuàng)建數(shù)據(jù)鏡像,這使得MongoDB有更強(qiáng)的擴(kuò)展性。如果負(fù)載的增加(需要更多的存儲(chǔ)空間和更強(qiáng)的處理能力),它可以分布在計(jì)算機(jī)網(wǎng)絡(luò)中的其他節(jié)點(diǎn)上(即所謂的分片)。
1、官網(wǎng)下載windows安裝包https://www.mongodb.com/download-center#community
2、點(diǎn)擊安裝包,按照指示安裝,選擇custom自定義安裝位置。注:我在安裝3.6版本的時(shí)候軟件報(bào)錯(cuò)無(wú)法完成安裝,查詢后發(fā)現(xiàn)將安裝最后一步時(shí)的compass框不勾選,即可完成安裝,如果需要compass,安裝之后再次點(diǎn)擊安裝程序,選擇change選項(xiàng),重新安裝compass。
3、配置mongodb:在你想要的位置新建三個(gè)文件:data文件夾(用于存放數(shù)據(jù)庫(kù)數(shù)據(jù)),logs/mongodb.log文件(用于存放數(shù)據(jù)庫(kù)日志),etc/mongodb.conf文件(用于相關(guān)配置)。打開mongodb.conf文件,輸入相關(guān)配置信息:
#數(shù)據(jù)庫(kù)路徑dbpath=D:/MongoDB/data#日志輸出文件路徑logpath=D:/MongoDB/logs/mongodb.log#錯(cuò)誤日志采用追加模式,配置這個(gè)選項(xiàng)后mongodb的日志會(huì)追加到現(xiàn)有的日志文件,而不是從新創(chuàng)建一個(gè)新文件logappend=true#啟用日志文件,默認(rèn)啟用journal=true#這個(gè)選項(xiàng)可以過濾掉一些無(wú)用的日志信息,若需要調(diào)試使用請(qǐng)?jiān)O(shè)置為falsequiet=true#端口號(hào) 默認(rèn)為27017port=27017
4、安裝mongo服務(wù):在mongo安裝目錄下的bin文件夾下打開命令行,輸入:
mongod --config "D:/MongoDB/etc/mongodb.conf" --install --serverName "MongoDB"
--config后跟剛才保存的配置文件地址,--serverName后跟創(chuàng)建的服務(wù)的名字
執(zhí)行之后在Windows10搜索服務(wù)可以看到mongodb服務(wù),點(diǎn)擊開啟:

或者在MongoDB /bin 目錄中執(zhí)行命令行 mongod --dbpath ../data,啟動(dòng)mongo服務(wù)。
5、打開命令行:配置環(huán)境變量,添加環(huán)境變量到MongoDB的bin文件夾下,這樣在任意位置新建一個(gè)命令行窗口,輸入mongo就可以開啟mongo的shell命令行了。
1、創(chuàng)建/切換到數(shù)據(jù)庫(kù):use DatabaseName,新建一個(gè)數(shù)據(jù)庫(kù)并不會(huì)顯示出來(lái),只有在向其中插入記錄后才會(huì)顯示
刪除數(shù)據(jù)庫(kù):
db.dropDatabase()
2、創(chuàng)建一個(gè)集合:
db.createCollection('mall')刪除集合mall:
db.mall.drop()
3、創(chuàng)建用戶。給數(shù)據(jù)庫(kù)mall創(chuàng)建一個(gè)用戶:
db.createUser({"user":"root",pwd:"mallroot",roles:[{role:'dbOwner',db:'mall'}]})4、向數(shù)據(jù)庫(kù)導(dǎo)入JSON文件。退出mongo,在cmd下執(zhí)行:
mongoimport -d mall -c user --file F:/resource/mall-users
就將mall-users文件導(dǎo)入到mall數(shù)據(jù)庫(kù)的user集合中
5、向集合mall中插入一條記錄:
db.mall.insert({"name":"小米6","price":"2699"})像json格式一樣,以鍵值對(duì)的形式(key=>value)將你想要插入的數(shù)據(jù)寫入即可。
6、刪除一條數(shù)據(jù):
db.mall.remove({mID:1005})刪除mID為1005的一條數(shù)據(jù),注意如果在插入的時(shí)候{mID:"1005"}為字符串類型,{mID:1005}為number類型
7、修改一條數(shù)據(jù):
db.mall.update({name:"小米6"},{$set:{price:"2399"}})update中第一個(gè)參數(shù)是修改數(shù)據(jù)的條件,第二個(gè)參數(shù)利用$set設(shè)置修改的鍵值
8、查看集合中的數(shù)據(jù):
db.mall.find()
在后面加.pretty()可以格式化查看其中數(shù)據(jù)。
條件查詢:
db.mall.find({price:{$lt:2000}})查詢price低于2000的條目
9、數(shù)組操作
占位符$代表數(shù)組的下標(biāo),例如只更新cartList數(shù)組中滿足條件的元素,
user.update({conditions},{ $set:{"cartList.$.productNum":productNum} })$addToSet: 如果數(shù)組中沒有該數(shù)據(jù),向數(shù)組中添加數(shù)據(jù),如果該數(shù)組中有相同數(shù)組,不添加
user.update({conditions},{ $addToSet:{cartList:cartItem} })$pop:刪除數(shù)組數(shù)據(jù),1從頭刪除,-1從尾刪除
user.update({conditions},{ $pop:{cartList:1} })$pull:刪除指定數(shù)據(jù),例如對(duì)指定userId下的cartList數(shù)組刪除其中指定的productId的元素
user.update({userId:userId},{ $pull:{ cartList:{productId:productId} } }$push:向數(shù)組中插入一個(gè)元素、$each 遍歷數(shù)組、$sort 對(duì)數(shù)組進(jìn)行排序、$slice 對(duì)數(shù)組進(jìn)行裁減、$position 指定插入數(shù)據(jù)的位置。
db.test.update( { _id: 5 }, { $push: { quizzes: { $each: [ { wk: 5, score: 2 }, { wk: 6, score: 1 }, { wk: 7, score: 3 } ], //遍歷插入數(shù)據(jù) $sort: { score: -1 }, //按score降序 $slice: 3, //裁剪只留下前三條數(shù)據(jù) $position:2 //從第二個(gè)位置開始插入 } } } );希望本文所述對(duì)大家MongoDB數(shù)據(jù)庫(kù)程序設(shè)計(jì)有所幫助。
新聞熱點(diǎn)
疑難解答
圖片精選