激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫(kù)技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫(kù) - MongoDB - MongoDB數(shù)據(jù)庫(kù)安裝配置、基本操作實(shí)例詳解

MongoDB數(shù)據(jù)庫(kù)安裝配置、基本操作實(shí)例詳解

2020-05-26 16:13theVicTory MongoDB

這篇文章主要介紹了MongoDB數(shù)據(jù)庫(kù)安裝配置、基本操作,結(jié)合實(shí)例形式詳細(xì)分析了MongoDB數(shù)據(jù)庫(kù)安裝配置具體步驟、相關(guān)命令與基本操作實(shí)現(xiàn)技巧,需要的朋友可以參考下

本文實(shí)例講述了MongoDB數(shù)據(jù)庫(kù)安裝配置、基本操作。分享給大家供大家參考,具體如下:

1、簡(jiǎn)介

 

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ǔ),這些類(lèi)型的數(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
- 沒(méi)有聲明性查詢語(yǔ)言
- 沒(méi)有預(yù)定義的模式
-鍵 - 值對(duì)存儲(chǔ),列存儲(chǔ),文檔存儲(chǔ)
- 最終一致性,而非ACID屬性
- 非結(jié)構(gòu)化和不可預(yù)知的數(shù)據(jù)
- CAP定理
- 高性能,高可用性和可伸縮性

 

MongoDB 是由C++語(yǔ)言編寫(xiě)的,是一個(gè)基于分布式文件存儲(chǔ)的開(kāi)源數(shù)據(jù)庫(kù)系統(tǒng)。MongoDB 將數(shù)據(jù)存儲(chǔ)為一個(gè)文檔,數(shù)據(jù)結(jié)構(gòu)由鍵值對(duì)(key=>value)組成。MongoDB 文檔類(lèi)似于 JSON 對(duì)象,可輕易查詢文檔中內(nèi)嵌的對(duì)象及數(shù)組。字段值可以包含其他文檔,數(shù)組及文檔數(shù)組??梢酝ㄟ^(guò)本地或者網(wǎng)絡(luò)創(chuàng)建數(shù)據(jù)鏡像,這使得MongoDB有更強(qiáng)的擴(kuò)展性。如果負(fù)載的增加(需要更多的存儲(chǔ)空間和更強(qiáng)的處理能力),它可以分布在計(jì)算機(jī)網(wǎng)絡(luò)中的其他節(jié)點(diǎn)上(即所謂的分片)。

2、安裝配置

 

    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)配置)。打開(kāi)mongodb.conf文件,輸入相關(guān)配置信息:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#數(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)可以過(guò)濾掉一些無(wú)用的日志信息,若需要調(diào)試使用請(qǐng)?jiān)O(shè)置為false
 
quiet=true
 
#端口號(hào) 默認(rèn)為27017
 
port=27017

4、安裝mongo服務(wù):在mongo安裝目錄下的bin文件夾下打開(kāi)命令行,輸入:

?
1
mongod --config "D:\MongoDB\etc\mongodb.conf" --install --serverName "MongoDB"

--config后跟剛才保存的配置文件地址,--serverName后跟創(chuàng)建的服務(wù)的名字

執(zhí)行之后在Windows10搜索服務(wù)可以看到mongodb服務(wù),點(diǎn)擊開(kāi)啟:

MongoDB數(shù)據(jù)庫(kù)安裝配置、基本操作實(shí)例詳解

或者在MongoDB /bin 目錄中執(zhí)行命令行  mongod --dbpath ../data,啟動(dòng)mongo服務(wù)。

5、打開(kāi)命令行:配置環(huán)境變量,添加環(huán)境變量到MongoDB的bin文件夾下,這樣在任意位置新建一個(gè)命令行窗口,輸入mongo就可以開(kāi)啟mongo的shell命令行了。

3、基本操作

 

1、創(chuàng)建/切換到數(shù)據(jù)庫(kù):use DatabaseName,新建一個(gè)數(shù)據(jù)庫(kù)并不會(huì)顯示出來(lái),只有在向其中插入記錄后才會(huì)顯示

刪除數(shù)據(jù)庫(kù):

?
1
db.dropDatabase()

2、創(chuàng)建一個(gè)集合:

?
1
db.createCollection('mall')

刪除集合mall:

?
1
db.mall.drop()

3、創(chuàng)建用戶。給數(shù)據(jù)庫(kù)mall創(chuàng)建一個(gè)用戶:

?
1
db.createUser({"user":"root",pwd:"mallroot",roles:[{role:'dbOwner',db:'mall'}]})

4、向數(shù)據(jù)庫(kù)導(dǎo)入JSON文件。退出mongo,在cmd下執(zhí)行:

?
1
mongoimport -d mall -c user --file F:\resource\mall-users

就將mall-users文件導(dǎo)入到mall數(shù)據(jù)庫(kù)的user集合中

5、向集合mall中插入一條記錄:

?
1
db.mall.insert({"name":"小米6","price":"2699"})

像json格式一樣,以鍵值對(duì)的形式(key=>value)將你想要插入的數(shù)據(jù)寫(xiě)入即可。

6、刪除一條數(shù)據(jù):

?
1
db.mall.remove({mID:1005})

刪除mID為1005的一條數(shù)據(jù),注意如果在插入的時(shí)候{mID:"1005"}為字符串類(lèi)型,{mID:1005}為number類(lèi)型

7、修改一條數(shù)據(jù):

?
1
db.mall.update({name:"小米6"},{$set:{price:"2399"}})

update中第一個(gè)參數(shù)是修改數(shù)據(jù)的條件,第二個(gè)參數(shù)利用$set設(shè)置修改的鍵值

8、查看集合中的數(shù)據(jù):

?
1
db.mall.find()

在后面加.pretty()可以格式化查看其中數(shù)據(jù)。

條件查詢:

?
1
db.mall.find({price:{$lt:2000}})

  查詢price低于2000的條目

9、數(shù)組操作

占位符$代表數(shù)組的下標(biāo),例如只更新cartList數(shù)組中滿足條件的元素,

?
1
2
3
user.update({conditions},{
  $set:{"cartList.$.productNum":productNum}
 })

$addToSet: 如果數(shù)組中沒(méi)有該數(shù)據(jù),向數(shù)組中添加數(shù)據(jù),如果該數(shù)組中有相同數(shù)組,不添加

?
1
2
3
user.update({conditions},{
  $addToSet:{cartList:cartItem}
 })

$pop:刪除數(shù)組數(shù)據(jù),1從頭刪除,-1從尾刪除

?
1
2
3
user.update({conditions},{
  $pop:{cartList:1}
 })

$pull:刪除指定數(shù)據(jù),例如對(duì)指定userId下的cartList數(shù)組刪除其中指定的productId的元素      

?
1
2
3
4
5
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ù)的位置。

?
1
2
3
4
5
6
7
8
9
10
11
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è)位置開(kāi)始插入
           }
      }
 }
 );

希望本文所述對(duì)大家MongoDB數(shù)據(jù)庫(kù)程序設(shè)計(jì)有所幫助。

原文鏈接:https://blog.csdn.net/theVicTory/article/details/79623117

延伸 · 閱讀

精彩推薦
  • MongoDBmongodb基本命令實(shí)例小結(jié)

    mongodb基本命令實(shí)例小結(jié)

    這篇文章主要介紹了mongodb基本命令,結(jié)合實(shí)例形式總結(jié)分析了MongoDB數(shù)據(jù)庫(kù)切換、查看、刪除、查詢等基本命令用法與操作注意事項(xiàng),需要的朋友可以參考下...

    dawn-liu3652020-05-26
  • MongoDBMongoDB安裝圖文教程

    MongoDB安裝圖文教程

    這篇文章主要為大家詳細(xì)介紹了MongoDB安裝圖文教程,分為兩大部分為大家介紹下載MongoDB和安裝MongoDB的方法,感興趣的小伙伴們可以參考一下 ...

    Yangyi.He6132020-05-07
  • MongoDBMongoDB中javascript腳本編程簡(jiǎn)介和入門(mén)實(shí)例

    MongoDB中javascript腳本編程簡(jiǎn)介和入門(mén)實(shí)例

    作為一個(gè)數(shù)據(jù)庫(kù),MongoDB有一個(gè)很大的優(yōu)勢(shì)——它使用js管理數(shù)據(jù)庫(kù),所以也能夠使用js腳本進(jìn)行復(fù)雜的管理——這種方法非常靈活 ...

    MongoDB教程網(wǎng)6982020-04-24
  • MongoDBMongoDB憑什么躋身數(shù)據(jù)庫(kù)排行前五

    MongoDB憑什么躋身數(shù)據(jù)庫(kù)排行前五

    MongoDB以比去年同期超出65.96分的成績(jī)繼續(xù)雄踞榜單前五,這個(gè)增幅在全榜僅次于PostgreSQL的77.99,而其相對(duì)于4月份的6.10分的增長(zhǎng)也是僅次于微軟SQL Server排名...

    孫浩峰3892020-05-22
  • MongoDBMongodb實(shí)現(xiàn)定時(shí)備份與恢復(fù)的方法教程

    Mongodb實(shí)現(xiàn)定時(shí)備份與恢復(fù)的方法教程

    這篇文章主要給大家介紹了Mongodb實(shí)現(xiàn)定時(shí)備份與恢復(fù)的方法教程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面...

    chenjsh364522020-05-13
  • MongoDB遷移sqlserver數(shù)據(jù)到MongoDb的方法

    遷移sqlserver數(shù)據(jù)到MongoDb的方法

    這篇文章主要介紹了遷移sqlserver數(shù)據(jù)到MongoDb的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下...

    聽(tīng)楓xl9682021-01-03
  • MongoDB分布式文檔存儲(chǔ)數(shù)據(jù)庫(kù)之MongoDB分片集群的問(wèn)題

    分布式文檔存儲(chǔ)數(shù)據(jù)庫(kù)之MongoDB分片集群的問(wèn)題

    這篇文章主要介紹了分布式文檔存儲(chǔ)數(shù)據(jù)庫(kù)之MongoDB分片集群的問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋...

    Linux-18743072020-12-20
  • MongoDBMongoDB 內(nèi)存使用情況分析

    MongoDB 內(nèi)存使用情況分析

    都說(shuō) MongoDB 是個(gè)內(nèi)存大戶,但是怎么知道它到底用了多少內(nèi)存呢...

    MongoDB教程網(wǎng)10002020-09-29
主站蜘蛛池模板: 精品国产91久久久久久久 | 日本免费aaa观看 | 欧美日韩精品一区二区三区蜜桃 | 国产91小视频在线观看 | 黄色片网站在线免费观看 | 蝌蚪久久窝 | 成人区一区二区三区 | 国产中出视频 | 国产老师做www爽爽爽视频 | 国产中文99视频在线观看 | 日韩在线黄| 日本最新免费二区三区 | 毛片在线免费观看完整版 | 狠狠久久伊人中文字幕 | 羞羞草视频 | 久草网在线 | 嫩草91在线 | 黄色特级| 国产乱淫av片免费观看 | 久精品久久 | 成人亚洲一区二区 | 欧美重口另类videos人妖 | 久久久国产一区二区三区 | 久久免费视频精品 | 亚洲午夜1000理论片aa | 免费一级特黄做受大片 | 露脸各种姿势啪啪的清纯美女 | 在线成人一区二区 | 日本大片在线播放 | 精品欧美一区二区精品久久 | 久久人人做 | 国产69精品久久99不卡免费版 | 国产精品久久77777 | 国产精品视频1区 | 久久日韩| 91午夜视频 | 羞羞视频免费网站 | 国产一区二区三区黄 | 全黄裸片武则天一级第4季 九色p | 91专区在线观看 | 久久人人爽人人爽人人片av高清 |