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