時(shí)間:2024-03-09 11:50作者:下載吧人氣:18
為了保存網(wǎng)站的用戶數(shù)據(jù)和業(yè)務(wù)數(shù)據(jù),通常需要一個(gè)數(shù)據(jù)庫。MongoDB和Node.js特別般配,因?yàn)镸ongodb是基于文檔的非關(guān)系型數(shù)據(jù)庫,文檔是按BSON(JSON的輕量化二進(jìn)制格式)存儲(chǔ)的,增刪改查等管理數(shù)據(jù)庫的命令和JavaScript語法很像。本文將詳細(xì)介紹MongoDB數(shù)據(jù)庫
數(shù)據(jù)庫
數(shù)據(jù)庫,顧名思義,是數(shù)據(jù)存儲(chǔ)的倉庫,主要功能有兩個(gè)
1、有組織地存放數(shù)據(jù)
與在磁盤上自己存放文件不同,數(shù)據(jù)庫替用戶組織了數(shù)據(jù)的存儲(chǔ)形式,用戶只需要按照數(shù)據(jù)庫提供的接口將數(shù)據(jù)寫入,數(shù)據(jù)便會(huì)按照標(biāo)準(zhǔn)的格式被存儲(chǔ)起來
2、按照不同的需求進(jìn)行查詢
數(shù)據(jù)庫不僅要能寫入數(shù)據(jù),還支持?jǐn)?shù)據(jù)查詢,并且能夠按照不同的需求進(jìn)行查詢。因?yàn)榇鎯?chǔ)是有組織的,因此查詢上可以更規(guī)范化,查詢速度也會(huì)快很多
不同的數(shù)據(jù)庫的區(qū)別就是存放數(shù)據(jù)的組織不同,同時(shí)提供了不同種類的查詢。用戶可以按照自己的需求,選擇合適的數(shù)據(jù)庫
【分類】
數(shù)據(jù)庫的分類有很多種,按照對(duì)SQL語言的支持,可以分為以下兩種:
1、SQL數(shù)據(jù)庫,比如Oracle、Mysql等
2、NoSQL數(shù)據(jù)庫,比如Redis、MongoDB等
隨著在規(guī)模互聯(lián)網(wǎng)應(yīng)用的出現(xiàn),傳統(tǒng)的SQL數(shù)據(jù)庫遇到了一些設(shè)計(jì)上的弊端。比如,SQL對(duì)表的定義使應(yīng)用不夠靈活,橫向擴(kuò)展比較困難。與一些特性難以滿足相比,反而是SQL數(shù)據(jù)庫的很多特性沒有用武之地。比如,在很多場(chǎng)景下,及時(shí)存取并不是必要的,也沒有特別多的事務(wù)需求,而這些額外的特性消耗著SQL數(shù)據(jù)庫的性能
因此NoSQL數(shù)據(jù)庫應(yīng)運(yùn)而生,NoSQL全稱是Not Only SQL,意即”不僅僅是SQL”。但事實(shí)上,絕大多數(shù)NoSQL數(shù)據(jù)庫都放棄了對(duì)SQL語言的支持。與SQL關(guān)系型數(shù)據(jù)庫相比,NoSQL非關(guān)系型數(shù)據(jù)庫大多放棄了一些特性。比如,放棄了實(shí)時(shí)一致性、對(duì)事務(wù)的完整支持以及多表查詢等。聽起來缺點(diǎn)很多,但收益也明顯,NoSQL數(shù)據(jù)庫簡單便捷、方便擴(kuò)展,并且有更好的性能
概述
MongoDB是一個(gè)開源的NoSQL數(shù)據(jù)庫,在國內(nèi)被稱為芒果數(shù)據(jù)庫。Linux、Apache、MySQL和PHP組成了非常有名的LAMP架構(gòu)。現(xiàn)在,有人提議將LAMP中的代表M的MySQL替換為MongoDB
NoSQL數(shù)據(jù)庫有很多,為什么要選擇MongoDB呢?
MongoDB 是一個(gè)基于分布式文件存儲(chǔ)的數(shù)據(jù)庫。由 C++ 語言編寫,旨在為 WEB 應(yīng)用提供可擴(kuò)展的高性能數(shù)據(jù)存儲(chǔ)解決方案。MongoDB使用集合(collection)和文檔(document)來描述和存儲(chǔ)數(shù)據(jù),集合(collection)就相當(dāng)于表,文檔(document)相當(dāng)于行,字段相當(dāng)于列,不像MySQL之類的關(guān)系型數(shù)據(jù)庫,表結(jié)構(gòu)是固定的,比如某一行由若干列組成,行行都一樣,而MongoDB不同,一個(gè)集合里的多個(gè)文檔可以有不同的結(jié)構(gòu),更靈活一些
MongoDB有自己很鮮明的特色,總結(jié)起來有以下4條
1、沒有表結(jié)構(gòu)的限制
傳統(tǒng)SQL數(shù)據(jù)庫中,對(duì)每張表都需要定義表結(jié)構(gòu)。如果有新的存儲(chǔ)需求,往往需要添加新的字段,更改表結(jié)構(gòu)。在一些場(chǎng)景下,會(huì)顯得很不方便,而對(duì)于MongoDB,這不再是問題。因?yàn)樗鼪]有表結(jié)構(gòu)這個(gè)概念,在使用一張表之前,不需要對(duì)這張表進(jìn)行任何初始化操作。MongoDB的這種特性對(duì)快捷開發(fā)和多變的業(yè)務(wù)需求是很合適的
2、完全的索引支持
有些NoSQL數(shù)據(jù)庫,比如redis,它是內(nèi)存數(shù)據(jù)庫,速度很快。但是,做為鍵值數(shù)據(jù)庫,只支持一種按鍵查詢的方式。靈活性、使用范圍和易用性都受到影響;再比如hbase,寫入速度很快。但是,同樣查詢受限,它只支持單索引,二級(jí)索引需要自己實(shí)現(xiàn)
而MongoDB支持單鍵索引、多鍵索引、全文索引和地理位置索引。所以MongoDB是功能非常完善的NoSQL數(shù)據(jù)庫,也被稱為最接近關(guān)系數(shù)據(jù)庫的非關(guān)系數(shù)據(jù)庫
3、良好的數(shù)據(jù)安全性和方便的規(guī)模擴(kuò)展
MongoDB使用復(fù)制集做多副本存儲(chǔ),以保證數(shù)據(jù)的安全性。同時(shí),MongoDB內(nèi)置的分片技術(shù)可以很方便地進(jìn)行數(shù)據(jù)規(guī)模的擴(kuò)展。分片技術(shù)是很新穎的一個(gè)特性,它包含了自動(dòng)數(shù)據(jù)接口,動(dòng)態(tài)擴(kuò)容和縮容等一系列在其他數(shù)據(jù)庫中需要大量人工操作的工作,同時(shí)提供了對(duì)數(shù)據(jù)庫的統(tǒng)一訪問入口,不需要在應(yīng)用層再進(jìn)行分發(fā),顯著減少了人工成本
4、完善的文檔支持和驅(qū)動(dòng)支持
安裝
首先,在官網(wǎng)的下載頁面選擇合適的MongoDB版本進(jìn)行下載
網(wǎng)友評(píng)論