欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

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

1、簡介

NO SQL:NoSQL(NoSQL = Not Only SQL ),意即"不僅僅是SQL",是對不同于傳統(tǒng)的關(guān)系數(shù)據(jù)庫管理系統(tǒng)(RDBMS)的統(tǒng)稱。NoSQL用于超大規(guī)模數(shù)據(jù)的存儲,這些類型的數(shù)據(jù)存儲不需要固定的模式,無需多余操作就可以橫向擴(kuò)展。

RDBMS NOSQL
- 高度組織化結(jié)構(gòu)化數(shù)據(jù)
- 結(jié)構(gòu)化查詢語言(SQL)
- 數(shù)據(jù)和關(guān)系都存儲在單獨(dú)的表中。
- 數(shù)據(jù)操縱語言,數(shù)據(jù)定義語言
- 嚴(yán)格的一致性
- 基礎(chǔ)事務(wù)
- 代表著不僅僅是SQL
- 沒有聲明性查詢語言
- 沒有預(yù)定義的模式
-鍵 - 值對存儲,列存儲,文檔存儲
- 最終一致性,而非ACID屬性
- 非結(jié)構(gòu)化和不可預(yù)知的數(shù)據(jù)
- CAP定理
- 高性能,高可用性和可伸縮性

MongoDB 是由C++語言編寫的,是一個(gè)基于分布式文件存儲的開源數(shù)據(jù)庫系統(tǒng)。MongoDB 將數(shù)據(jù)存儲為一個(gè)文檔,數(shù)據(jù)結(jié)構(gòu)由鍵值對(key=>value)組成。MongoDB 文檔類似于 JSON 對象,可輕易查詢文檔中內(nèi)嵌的對象及數(shù)組。字段值可以包含其他文檔,數(shù)組及文檔數(shù)組??梢酝ㄟ^本地或者網(wǎng)絡(luò)創(chuàng)建數(shù)據(jù)鏡像,這使得MongoDB有更強(qiáng)的擴(kuò)展性。如果負(fù)載的增加(需要更多的存儲空間和更強(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ò)無法完成安裝,查詢后發(fā)現(xiàn)將安裝最后一步時(shí)的compass框不勾選,即可完成安裝,如果需要compass,安裝之后再次點(diǎn)擊安裝程序,選擇change選項(xiàng),重新安裝compass。

    3、配置mongodb:在你想要的位置新建三個(gè)文件:data文件夾(用于存放數(shù)據(jù)庫數(shù)據(jù)),logs\mongodb.log文件(用于存放數(shù)據(jù)庫日志),etc\mongodb.conf文件(用于相關(guān)配置)。打開mongodb.conf文件,輸入相關(guān)配置信息:

#數(shù)據(jù)庫路徑

dbpath=D:\MongoDB\data

#日志輸出文件路徑

logpath=D:\MongoDB\logs\mongodb.log

#錯(cuò)誤日志采用追加模式,配置這個(gè)選項(xiàng)后mongodb的日志會追加到現(xiàn)有的日志文件,而不是從新創(chuàng)建一個(gè)新文件

logappend=true

#啟用日志文件,默認(rèn)啟用

journal=true

#這個(gè)選項(xiàng)可以過濾掉一些無用的日志信息,若需要調(diào)試使用請?jiān)O(shè)置為false

quiet=true

#端口號 默認(rèn)為27017

port=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,啟動mongo服務(wù)。

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

3、基本操作

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

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

db.dropDatabase()

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

db.createCollection('mall')

刪除集合mall:

db.mall.drop()

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

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

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

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

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

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

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

像json格式一樣,以鍵值對的形式(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ù),例如對指定userId下的cartList數(shù)組刪除其中指定的productId的元素      

user.update({userId:userId},{
  $pull:{
   cartList:{productId:productId}
  }
 }

$push:向數(shù)組中插入一個(gè)元素、$each 遍歷數(shù)組、$sort 對數(shù)組進(jìn)行排序、$slice 對數(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è)位置開始插入
           }
      }
 }
 );

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

相關(guān)文章

  • MongoDB連接數(shù)據(jù)庫并創(chuàng)建數(shù)據(jù)等使用方法

    MongoDB連接數(shù)據(jù)庫并創(chuàng)建數(shù)據(jù)等使用方法

    MongoDB?是一個(gè)介于關(guān)系數(shù)據(jù)庫和非關(guān)系數(shù)據(jù)庫之間的產(chǎn)品,是非關(guān)系數(shù)據(jù)庫當(dāng)中功能最豐富,最像關(guān)系數(shù)據(jù)庫的。接下來通過本文給大家介紹MongoDB連接數(shù)據(jù)庫并創(chuàng)建數(shù)據(jù)等使用方法,感興趣的朋友一起看看吧
    2021-11-11
  • 詳解MongoDB中的日志模塊

    詳解MongoDB中的日志模塊

    這篇文章主要介紹了MongoDB中的日志模塊的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用MongoDB數(shù)據(jù)庫,感興趣的朋友可以了解下
    2021-04-04
  • Mongodb使用索引進(jìn)行查詢優(yōu)化的操作方法

    Mongodb使用索引進(jìn)行查詢優(yōu)化的操作方法

    為集合建立合適的索引,能夠有效的減少查詢操作時(shí)掃描數(shù)據(jù)的數(shù)量 ,從而提高查詢效率,簡化了mongodb內(nèi)部查詢工作,這篇文章主要介紹了Mongodb使用索引進(jìn)行查詢優(yōu)化的操作方法,需要的朋友可以參考下
    2024-06-06
  • Mongodb通配符文本索引的用法詳解

    Mongodb通配符文本索引的用法詳解

    通配符索引為Mongodb靈活的數(shù)據(jù)結(jié)構(gòu),提供了高效查詢的解決方案,本文繼續(xù)研究官方文檔,來歸納總結(jié)通配符文本索引的介紹和用法,感興趣的朋友跟隨小編一起看看吧
    2024-07-07
  • MongoDB 中Limit與Skip的使用方法詳解

    MongoDB 中Limit與Skip的使用方法詳解

    這篇文章主要介紹了MongoDB 中Limit與Skip的使用方法詳解的相關(guān)資料,這里對這兩種方法進(jìn)行了詳細(xì)介紹并附示例代碼,幫助大家學(xué)習(xí)理解,需要的朋友可以參考下
    2017-07-07
  • MongoDB 常用的crud操作語句

    MongoDB 常用的crud操作語句

    本篇介紹了 MongoDB 的基本 CRUD 操作,可以看到 MongoDB 的語法極其簡潔,而且可以使用鏈?zhǔn)秸{(diào)用的方式進(jìn)行操作。操作的參數(shù)也很固定,且方法名稱很明確,上手來說是很容易的
    2021-06-06
  • 2021最新版windows10系統(tǒng)MongoDB數(shù)據(jù)庫安裝及配置環(huán)境

    2021最新版windows10系統(tǒng)MongoDB數(shù)據(jù)庫安裝及配置環(huán)境

    這篇文章主要介紹了2021最新版MongoDB數(shù)據(jù)庫安裝及配置環(huán)境(windows10系統(tǒng)),本文通過圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • MongoDB自動刪除過期數(shù)據(jù)的方法(TTL索引)

    MongoDB自動刪除過期數(shù)據(jù)的方法(TTL索引)

    這篇文章主要給大家介紹了關(guān)于MongoDB自動刪除過期數(shù)據(jù)(TTL索引)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-11-11
  • mongodb三分鐘入門大全

    mongodb三分鐘入門大全

    MongoDB是一個(gè)介于關(guān)系數(shù)據(jù)庫和非關(guān)系數(shù)據(jù)庫之間的產(chǎn)品,是非關(guān)系數(shù)據(jù)庫當(dāng)中功能最豐富,最像關(guān)系數(shù)據(jù)庫的,接下來通過本文給大家介紹mongodb三分鐘入門大全,感興趣的朋友一起看看吧
    2022-01-01
  • mongodb數(shù)據(jù)庫的6個(gè)安全設(shè)置命令

    mongodb數(shù)據(jù)庫的6個(gè)安全設(shè)置命令

    這篇文章主要介紹了mongodb數(shù)據(jù)庫的6個(gè)安全設(shè)置命令,如安全模式啟動、安全認(rèn)證、數(shù)據(jù)讀寫加鎖、解鎖等,需要的朋友可以參考下
    2014-05-05

最新評論