1. 程式人生 > 資料庫 >MongoDB資料庫安裝配置、基本操作例項詳解

MongoDB資料庫安裝配置、基本操作例項詳解

本文例項講述了MongoDB資料庫安裝配置、基本操作。分享給大家供大家參考,具體如下:

1、簡介

NO SQL:NoSQL(NoSQL = Not Only SQL ),意即"不僅僅是SQL",是對不同於傳統的關係資料庫管理系統(RDBMS)的統稱。NoSQL用於超大規模資料的儲存,這些型別的資料儲存不需要固定的模式,無需多餘操作就可以橫向擴充套件。

RDBMS NOSQL
- 高度組織化結構化資料
- 結構化查詢語言(SQL)
- 資料和關係都儲存在單獨的表中。
- 資料操縱語言,資料定義語言
- 嚴格的一致性
- 基礎事務
- 代表著不僅僅是SQL
- 沒有宣告性查詢語言
- 沒有預定義的模式
-鍵 - 值對儲存,列儲存,文件儲存
- 最終一致性,而非ACID屬性
- 非結構化和不可預知的資料
- CAP定理
- 高效能,高可用性和可伸縮性

MongoDB 是由C++語言編寫的,是一個基於分散式檔案儲存的開源資料庫系統。MongoDB 將資料儲存為一個文件,資料結構由鍵值對(key=>value)組成。MongoDB 文件類似於 JSON 物件,可輕易查詢文件中內嵌的物件及陣列。欄位值可以包含其他文件,陣列及文件陣列。可以通過本地或者網路建立資料映象,這使得MongoDB有更強的擴充套件性。如果負載的增加(需要更多的儲存空間和更強的處理能力),它可以分佈在計算機網路中的其他節點上(即所謂的分片)。

2、安裝配置

1、官網下載windows安裝包https://www.mongodb.com/download-center#community

2、點選安裝包,按照指示安裝,選擇custom自定義安裝位置。注:我在安裝3.6版本的時候軟體報錯無法完成安裝,查詢後發現將安裝最後一步時的compass框不勾選,即可完成安裝,如果需要compass,安裝之後再次點選安裝程式,選擇change選項,重新安裝compass。

3、配置mongodb:在你想要的位置新建三個檔案:data資料夾(用於存放資料庫資料),logs\mongodb.log檔案(用於存放資料庫日誌),etc\mongodb.conf檔案(用於相關配置)。開啟mongodb.conf檔案,輸入相關配置資訊:

#資料庫路徑

dbpath=D:\MongoDB\data

#日誌輸出檔案路徑

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

#錯誤日誌採用追加模式,配置這個選項後mongodb的日誌會追加到現有的日誌檔案,而不是從新建立一個新檔案

logappend=true

#啟用日誌檔案,預設啟用

journal=true

#這個選項可以過濾掉一些無用的日誌資訊,若需要除錯使用請設定為false

quiet=true

#埠號 預設為27017

port=27017

4、安裝mongo服務:在mongo安裝目錄下的bin資料夾下開啟命令列,輸入:

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

--config後跟剛才儲存的配置檔案地址,--serverName後跟建立的服務的名字

執行之後在Windows10搜尋服務可以看到mongodb服務,點選開啟:

或者在MongoDB /bin 目錄中執行命令列 mongod --dbpath ../data,啟動mongo服務。

5、開啟命令列:配置環境變數,新增環境變數到MongoDB的bin資料夾下,這樣在任意位置新建一個命令列視窗,輸入mongo就可以開啟mongo的shell命令行了。

3、基本操作

1、建立/切換到資料庫:use DatabaseName,新建一個數據庫並不會顯示出來,只有在向其中插入記錄後才會顯示

刪除資料庫:

db.dropDatabase()

2、建立一個集合:

db.createCollection('mall')

刪除集合mall:

db.mall.drop()

3、建立使用者。給資料庫mall建立一個使用者:

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

4、向資料庫匯入JSON檔案。退出mongo,在cmd下執行:

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

就將mall-users檔案匯入到mall資料庫的user集合中

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

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

像json格式一樣,以鍵值對的形式(key=>value)將你想要插入的資料寫入即可。

6、刪除一條資料:

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

刪除mID為1005的一條資料,注意如果在插入的時候{mID:"1005"}為字串型別,{mID:1005}為number型別

7、修改一條資料:

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

update中第一個引數是修改資料的條件,第二個引數利用$set設定修改的鍵值

8、檢視集合中的資料:

db.mall.find()

在後面加.pretty()可以格式化檢視其中資料。

條件查詢:

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

查詢price低於2000的條目

9、陣列操作

佔位符$代表陣列的下標,例如只更新cartList陣列中滿足條件的元素,

user.update({conditions},{
  $set:{"cartList.$.productNum":productNum}
 })

$addToSet: 如果陣列中沒有該資料,向陣列中新增資料,如果該陣列中有相同陣列,不新增

user.update({conditions},{
  $addToSet:{cartList:cartItem}
 })

$pop:刪除陣列資料,1從頭刪除,-1從尾刪除

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

$pull:刪除指定資料,例如對指定userId下的cartList陣列刪除其中指定的productId的元素

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

$push:向陣列中插入一個元素、$each 遍歷陣列、$sort 對陣列進行排序、$slice 對陣列進行裁減、$position 指定插入資料的位置。

db.test.update( { _id: 5 },{ $push: { quizzes: { $each: [ { wk: 5,score: 2 },{ wk: 6,score: 1 },{ wk: 7,score: 3 } ],//遍歷插入資料
            $sort: { score: -1 },//按score降序
            $slice: 3,//裁剪只留下前三條資料
            $position:2          //從第二個位置開始插入
           }
      }
 }
 );

希望本文所述對大家MongoDB資料庫程式設計有所幫助。