1. 簡介
MongoDB 是由 C++語言編寫的,是一個基于分布式文件存儲的開源數(shù)據(jù)庫系統(tǒng)。在高負載的情 況下,添加更多的節(jié)點,可以保證服務(wù)器性能。MongoDB 旨在為 WEB 應(yīng)用提供可擴展的高性能數(shù)據(jù)存儲解決方案。
MongoDB 將數(shù)據(jù)存儲為一個文檔,數(shù)據(jù)結(jié)構(gòu)由鍵值(key=>value)對組成。MongoDB 文檔類似于 JSON 對象。字段值可以包含其他文檔,數(shù)組及文檔數(shù)組。
2. MongoDB的特點
MongoDB 是一個面向文檔存儲的數(shù)據(jù)庫,操作起來比較簡單和容易。
你可以在 MongoDB 記錄中設(shè)置任何屬性的索引 (如:FirstName="Sameer",Address="8 Ga
ndhi Road")來實現(xiàn)更快的排序。
你可以通過本地或者網(wǎng)絡(luò)創(chuàng)建數(shù)據(jù)鏡像,這使得 MongoDB 有更強的擴展性。
如果負載的增加(需要更多的存儲空間和更強的處理能力) ,它可以分布在計算機網(wǎng)絡(luò)中的其他節(jié)點上這就是所謂的分片。
Mongo 支持豐富的查詢表達式。查詢指令使用 JSON 形式的標記,可輕易查詢文檔中內(nèi)嵌的對象及數(shù)組。
MongoDb 使用 update()命令可以實現(xiàn)替換完成的文檔(數(shù)據(jù))或者一些指定的數(shù)據(jù)字段 。
Mongodb 中的 Map/reduce 主要是用來對數(shù)據(jù)進行批量處理和聚合操作。
Map 和 Reduce。Map 函數(shù)調(diào)用 emit(key,value)遍歷集合中所有的記錄,將 key 與 value 傳給 Reduce 函數(shù)進行處理。
Map 函數(shù)和 Reduce 函數(shù)是使用 Javascript 編寫的,并可以通過 db.runCommand 或 mapreduce 命令來執(zhí)行 MapReduce 操作。
GridFS 是 MongoDB 中的一個內(nèi)置功能,可以用于存放大量小文件。
MongoDB 允許在服務(wù)端執(zhí)行腳本,可以用 Javascript 編寫某個函數(shù),直接在服務(wù)端執(zhí)行,也可以把函數(shù)的定義存儲在服務(wù)端,下次直接調(diào)用即可。