什么是MongoDB ?
MongoDB 是由C++語言編寫的,是一個基于分布式文件存儲的開源數據庫系統。
在高負載的情況下,添加更多的節點,可以保證服務器性能。
MongoDB 旨在為WEB應用提供可擴展的高性能數據存儲解決方案。
MongoDB 將數據存儲為一個文檔,數據結構由鍵值(key=>value)對組成。MongoDB 文檔類似于 JSON 對象。字段值可以包含其他文檔,數組及文檔數組。
主要特點
- MongoDB的提供了一個面向文檔存儲,操作起來比較簡單和容易。
- 你可以在MongoDB記錄中設置任何屬性的索引 (如:FirstName="Sameer",Address="8 Gandhi Road")來實現更快的排序。
- 你可以通過本地或者網絡創建數據鏡像,這使得MongoDB有更強的擴展性。
- 如果負載的增加(需要更多的存儲空間和更強的處理能力) ,它可以分布在計算機網絡中的其他節點上這就是所謂的分片。
- Mongo支持豐富的查詢表達式。查詢指令使用JSON形式的標記,可輕易查詢文檔中內嵌的對象及數組。
- MongoDb 使用update()命令可以實現替換完成的文檔(數據)或者一些指定的數據字段 。
- Mongodb中的Map/reduce主要是用來對數據進行批量處理和聚合操作。
- Map和Reduce。Map函數調用emit(key,value)遍歷集合中所有的記錄,將key與value傳給Reduce函數進行處理。
- Map函數和Reduce函數是使用Javascript編寫的,并可以通過db.runCommand或mapreduce命令來執行MapReduce操作。
- GridFS是MongoDB中的一個內置功能,可以用于存放大量小文件。
- MongoDB允許在服務端執行腳本,可以用Javascript編寫某個函數,直接在服務端執行,也可以把函數的定義存儲在服務端,下次直接調用即可。
- MongoDB支持各種編程語言:RUBY,PYTHON,JAVA,C++,PHP,C#等多種語言。
- MongoDB安裝簡單。
歷史 2007年10月,MongoDB由10gen團隊所發展。2009年2月首度推出。
- 2012年05月23日,MongoDB2.1 開發分支發布了! 該版本采用全新架構,包含諸多增強。
- 2012年06月06日,MongoDB 2.0.6 發布,分布式文檔數據庫。
- 2013年04月23日,MongoDB 2.4.3 發布,此版本包括了一些性能優化,功能增強以及bug修復。
- 2013年08月20日,MongoDB 2.4.6 發布,是目前最新的穩定版。
MongoDB 下載
你可以在mongodb官網下載該安裝包,地址為:?http://www.mongodb.org/downloads。MonggoDB支持以下平臺:
- OS X 32-bit
- OS X 64-bit
- Linux 32-bit
- Linux 64-bit
- Windows 32-bit
- Windows 64-bit
- Solaris i86pc
- Solaris 64
MongoDB 工具
有幾種可用于MongoDB的管理工具。
監控
MongoDB提供了網絡和系統監控工具Munin,它作為一個插件應用于MongoDB中。
Gangila是MongoDB高性能的系統監視的工具,它作為一個插件應用于MongoDB中。
基于圖形界面的開源工具 Cacti, 用于查看CPU負載, 網絡帶寬利用率,它也提供了一個應用于監控 MongoDB 的插件。
GUI
- Fang of Mongo – 網頁式,由Django和jQuery所構成。
- Futon4Mongo – 一個CouchDB Futon web的mongodb山寨版。
- Mongo3 – Ruby寫成。
- MongoHub – 適用于OSX的應用程序。
- Opricot – 一個基于瀏覽器的MongoDB控制臺, 由PHP撰寫而成。
- Database Master — Windows的mongodb管理工具
- RockMongo — 最好的PHP語言的MongoDB管理工具,輕量級, 支持多國語言.
?
MongoDB 概念解析?
SQL術語/概念 | MongoDB術語/概念 | 解釋/說明 |
---|---|---|
database | database | 數據庫 |
table | collection | 數據庫表/集合 |
row | document | 數據記錄行/文檔 |
column | field | 數據字段/域 |
index | index | 索引 |
table joins | 表連接,MongoDB不支持 | |
primary key | primary key | 主鍵,MongoDB自動將_id字段設置為主鍵 |
?MongoDB的常用命令
這里只有部分常用命令,具體可以去:MongoDB中文網
-
查詢數據:
- find:查詢一個集合中的文檔。
- findOne:查詢符合條件的第一個文檔。
- count:統計符合條件的文檔數量。
- distinct:獲取指定字段的不重復值。
-
插入數據:
- insertOne:向集合中插入一個文檔。
- insertMany:向集合中插入多個文檔。
-
更新數據:
- updateOne:更新符合條件的第一個文檔。
- updateMany:更新符合條件的所有文檔。
- $set:用于設置文檔中的字段值。
-
刪除數據:
- deleteOne:刪除符合條件的第一個文檔。
- deleteMany:刪除符合條件的所有文檔。
- drop:刪除整個集合。
-
索引操作:
- createIndex:創建索引。
- dropIndex:刪除索引。
- explain:解釋查詢執行計劃。
-
聚合操作:
- aggregate:執行聚合操作,如統計、分組、排序等。
-
數據庫操作:
- show dbs:顯示所有數據庫。
- use:切換到指定數據庫。
- db.dropDatabase():刪除當前數據庫。?
-
條件查詢:
- $eq:等于
- $ne:不等于
- $gt:大于
- $gte:大于等于
- $lt:小于
- $lte:小于等于
- $in:匹配數組中的任意一個元素
- $nin:不匹配數組中的任意一個元素
- $and:同時滿足多個條件
- $or:滿足任意一個條件
- $not:不滿足指定條件
-
排序和限制查詢結果:
- sort:按指定字段排序結果
- limit:限制查詢結果數量
- skip:跳過指定數量的文檔
-
數據備份和恢復:
- mongodump:備份數據庫
- mongorestore:恢復數據庫
-
集合操作:
- createCollection:創建集合
- dropCollection:刪除集合
- renameCollection:重命名集合
-
用戶管理:
- createUser:創建用戶
- updateUser:更新用戶信息
- dropUser:刪除用戶
?
月下飲茶,念卿天涯