a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 數據庫 > MongoDB > 正文

MongoDB數據庫安裝配置、基本操作實例詳解

2020-10-29 18:40:55
字體:
來源:轉載
供稿:網友

本文實例講述了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#這個選項可以過濾掉一些無用的日志信息,若需要調試使用請設置為falsequiet=true#端口號 默認為27017port=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數據庫程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美瑟瑟| 亚洲精品无 | 国产精品毛片一区二区三区 | 国产成人午夜高潮毛片 | 在线观看日韩一区 | 中文字幕在线亚洲 | 亚洲视频区 | 亚洲精品久久久久久久久久久久久 | 99精品欧美一区二区三区 | 日韩在线高清 | 日韩在线中文字幕 | 欧美成人精品在线观看 | 日批视频在线播放 | 亚洲欧美日韩国产 | 日韩久久成人 | 久久国产综合 | 婷婷色婷婷 | 亚洲一区二区三区视频 | 欧美五月婷婷 | 欧美日本高清视频 | 国产在线久 | 国产精品揄拍一区二区久久国内亚洲精 | 欧美成人激情视频 | 日本一区二区三区四区不卡视频 | 成年免费观看视频 | 久久久久久久久久久久久久久久久久久 | 男人天堂av网站 | 亚洲精品乱 | 日韩久久久一区二区 | 亚洲精品无 | 日韩精品视频一区二区三区 | 日韩av视屏| 久热热| 国产一区二区三区免费在线观看 | 91综合网 | 农村妇女毛片精品久久久 | 欧美一级全黄 | 亚洲日本aⅴ片在线观看香蕉 | xxxx免费视频 | 色综合999 | 亚洲精品9999 |