為了保存網(wǎng)站的用戶數(shù)據(jù)和業(yè)務(wù)數(shù)據(jù),通常需要一個數(shù)據(jù)庫。MongoDB和Node.js特別般配,因為Mongodb是基于文檔的非關(guān)系型數(shù)據(jù)庫,文檔是按BSON(JSON的輕量化二進(jìn)制格式)存儲的,增刪改查等管理數(shù)據(jù)庫的命令和JavaScript語法很像。本文將詳細(xì)介紹MongoDB數(shù)據(jù)庫
數(shù)據(jù)庫
數(shù)據(jù)庫,顧名思義,是數(shù)據(jù)存儲的倉庫,主要功能有兩個
1、有組織地存放數(shù)據(jù)
與在磁盤上自己存放文件不同,數(shù)據(jù)庫替用戶組織了數(shù)據(jù)的存儲形式,用戶只需要按照數(shù)據(jù)庫提供的接口將數(shù)據(jù)寫入,數(shù)據(jù)便會按照標(biāo)準(zhǔn)的格式被存儲起來
2、按照不同的需求進(jìn)行查詢
數(shù)據(jù)庫不僅要能寫入數(shù)據(jù),還支持?jǐn)?shù)據(jù)查詢,并且能夠按照不同的需求進(jìn)行查詢。因為存儲是有組織的,因此查詢上可以更規(guī)范化,查詢速度也會快很多
不同的數(shù)據(jù)庫的區(qū)別就是存放數(shù)據(jù)的組織不同,同時提供了不同種類的查詢。用戶可以按照自己的需求,選擇合適的數(shù)據(jù)庫
【分類】
數(shù)據(jù)庫的分類有很多種,按照對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è)計上的弊端。比如,SQL對表的定義使應(yīng)用不夠靈活,橫向擴展比較困難。與一些特性難以滿足相比,反而是SQL數(shù)據(jù)庫的很多特性沒有用武之地。比如,在很多場景下,及時存取并不是必要的,也沒有特別多的事務(wù)需求,而這些額外的特性消耗著SQL數(shù)據(jù)庫的性能
因此NoSQL數(shù)據(jù)庫應(yīng)運而生,NoSQL全稱是Not Only SQL,意即"不僅僅是SQL"。但事實上,絕大多數(shù)NoSQL數(shù)據(jù)庫都放棄了對SQL語言的支持。與SQL關(guān)系型數(shù)據(jù)庫相比,NoSQL非關(guān)系型數(shù)據(jù)庫大多放棄了一些特性。比如,放棄了實時一致性、對事務(wù)的完整支持以及多表查詢等。聽起來缺點很多,但收益也明顯,NoSQL數(shù)據(jù)庫簡單便捷、方便擴展,并且有更好的性能
概述
MongoDB是一個開源的NoSQL數(shù)據(jù)庫,在國內(nèi)被稱為芒果數(shù)據(jù)庫。Linux、Apache、MySQL和PHP組成了非常有名的LAMP架構(gòu)?,F(xiàn)在,有人提議將LAMP中的代表M的MySQL替換為MongoDB
NoSQL數(shù)據(jù)庫有很多,為什么要選擇MongoDB呢?
MongoDB 是一個基于分布式文件存儲的數(shù)據(jù)庫。由 C++ 語言編寫,旨在為 WEB 應(yīng)用提供可擴展的高性能數(shù)據(jù)存儲解決方案。MongoDB使用集合(collection)和文檔(document)來描述和存儲數(shù)據(jù),集合(collection)就相當(dāng)于表,文檔(document)相當(dāng)于行,字段相當(dāng)于列,不像MySQL之類的關(guān)系型數(shù)據(jù)庫,表結(jié)構(gòu)是固定的,比如某一行由若干列組成,行行都一樣,而MongoDB不同,一個集合里的多個文檔可以有不同的結(jié)構(gòu),更靈活一些
MongoDB有自己很鮮明的特色,總結(jié)起來有以下4條
1、沒有表結(jié)構(gòu)的限制
傳統(tǒng)SQL數(shù)據(jù)庫中,對每張表都需要定義表結(jié)構(gòu)。如果有新的存儲需求,往往需要添加新的字段,更改表結(jié)構(gòu)。在一些場景下,會顯得很不方便,而對于MongoDB,這不再是問題。因為它沒有表結(jié)構(gòu)這個概念,在使用一張表之前,不需要對這張表進(jìn)行任何初始化操作。MongoDB的這種特性對快捷開發(fā)和多變的業(yè)務(wù)需求是很合適的
2、完全的索引支持
有些NoSQL數(shù)據(jù)庫,比如redis,它是內(nèi)存數(shù)據(jù)庫,速度很快。但是,做為鍵值數(shù)據(jù)庫,只支持一種按鍵查詢的方式。靈活性、使用范圍和易用性都受到影響;再比如hbase,寫入速度很快。但是,同樣查詢受限,它只支持單索引,二級索引需要自己實現(xiàn)
而MongoDB支持單鍵索引、多鍵索引、全文索引和地理位置索引。所以MongoDB是功能非常完善的NoSQL數(shù)據(jù)庫,也被稱為最接近關(guān)系數(shù)據(jù)庫的非關(guān)系數(shù)據(jù)庫
3、良好的數(shù)據(jù)安全性和方便的規(guī)模擴展
MongoDB使用復(fù)制集做多副本存儲,以保證數(shù)據(jù)的安全性。同時,MongoDB內(nèi)置的分片技術(shù)可以很方便地進(jìn)行數(shù)據(jù)規(guī)模的擴展。分片技術(shù)是很新穎的一個特性,它包含了自動數(shù)據(jù)接口,動態(tài)擴容和縮容等一系列在其他數(shù)據(jù)庫中需要大量人工操作的工作,同時提供了對數(shù)據(jù)庫的統(tǒng)一訪問入口,不需要在應(yīng)用層再進(jìn)行分發(fā),顯著減少了人工成本
4、完善的文檔支持和驅(qū)動支持
安裝
首先,在官網(wǎng)的下載頁面選擇合適的MongoDB版本進(jìn)行下載
然后,一步一步進(jìn)行安裝即可
默認(rèn)情況下,安裝到C盤的Program Files文件夾下的MongoDB文件夾中
服務(wù)器配置
【搭建服務(wù)器】
搭建服務(wù)器,需要進(jìn)行以下幾個步驟
1、創(chuàng)建data文件夾存儲數(shù)據(jù)庫的數(shù)據(jù)文件;創(chuàng)建log文件夾存儲數(shù)據(jù)庫的日志文件;創(chuàng)建bin文件夾存儲數(shù)據(jù)庫的可執(zhí)行文件;創(chuàng)建conf文件夾來存儲數(shù)據(jù)庫的配置文件
2、在windows系統(tǒng)下需要設(shè)置環(huán)境變量,否則在命令行中會提示mongod命令不可用
在環(huán)境變量的path中,添加mongod.exe文件的目錄
3、接下來,有兩種方式啟動mongoDB服務(wù),一種如下所示,設(shè)置dppath參數(shù)值為自定義的目錄路徑
mongod --dbpath=D:/app/mongo/data
由下圖看出,mongodb的默認(rèn)端口是27017
4、另一種是在conf文件夾下新建mongod.conf文件,在這個文件中將設(shè)置mongodb啟動的配置參數(shù)
dbpath = datalogpath = log/mongod.log
mongod -f conf/mongod.conf
這種方法在命令行工具中沒有任何提示,因為記錄已經(jīng)保存到日志文件中,此時mongodb服務(wù)已經(jīng)正常開啟
【連接服務(wù)器】
在搭建好mongodb服務(wù)器之后,需要使用客戶端mongo進(jìn)行連接,才能進(jìn)行下一步的操作
因為是使用mongo連接mongodb服務(wù)器,所以需要保證啟動mongodb服務(wù)器的命令行工具不被關(guān)閉,新開一個命令行工具,并輸入mongo 127.0.0.1/test,test為數(shù)據(jù)庫的名稱
【關(guān)閉mongod服務(wù)】
首先切換到admin數(shù)據(jù)庫(use admin),然后使用db.shutdownServer()命令來關(guān)閉服務(wù)
數(shù)據(jù)庫操作
【默認(rèn)】
MongoDB 中默認(rèn)的數(shù)據(jù)庫為 test,如果沒有創(chuàng)建新的數(shù)據(jù)庫,集合將存放在 test 數(shù)據(jù)庫中
【查看】
使用show dbs來查看數(shù)據(jù)庫
【創(chuàng)建/切換】
使用use命令來切換/創(chuàng)建數(shù)據(jù)庫,會發(fā)現(xiàn)創(chuàng)建的數(shù)據(jù)庫并不在數(shù)據(jù)庫的列表中, 要顯示它,需要向數(shù)據(jù)庫插入一些數(shù)據(jù)
【顯示當(dāng)前數(shù)據(jù)庫】
使用db命令來顯示當(dāng)前數(shù)據(jù)庫
【將數(shù)據(jù)寫入集合中】
使用db.集合名.insert(文檔)來將文檔的數(shù)據(jù)寫入集合中,文檔的格式為JSON。而所有存儲在集合中的數(shù)據(jù)都是BSON格式。BSON是一種類json的一種二進(jìn)制形式的存儲格式,簡稱Binary JSON。
db.collection_name.insert()
【查看集合】
上面的插入操作,會自動創(chuàng)建集合db1_coll1,使用show collections命令可以查看當(dāng)前數(shù)據(jù)庫中的所有集合
【刪除數(shù)據(jù)庫】
這將刪除當(dāng)前所選數(shù)據(jù)庫。 如果沒有選擇任何數(shù)據(jù)庫,那么它將刪除默認(rèn)的'test
‘?dāng)?shù)據(jù)庫
集合操作
集合類似于SQL數(shù)據(jù)庫中的數(shù)據(jù)表,標(biāo)識為collection
【查看集合】
可以使用命令show collections
檢查創(chuàng)建的集合
[注意]也可以使用show tables來查看集合
【創(chuàng)建集合】
在插入文檔時,MongoDB首先檢查上限集合capped
字段的大小,然后檢查max
字段
db.createCollection(name, {capped: Boolean>, autoIndexId: Boolean>, size: number>, max number>} )
name:集合的名字
capped:是否啟用集合限制,如果開啟需要制定一個限制條件,默認(rèn)為不啟用,這個參數(shù)沒有實際意義
max:集合中最大條數(shù)限制,默認(rèn)為沒有限制
size:限制集合使用空間的大小,默認(rèn)為沒有限制,size的優(yōu)先級比max要高
autoIndexId:是否使用_id作為索引,默認(rèn)為使用(true或false)
[注意]向集合中插入文檔時,如果集合不存在 ,則會自動創(chuàng)建集合
【刪除集合】
MongoDB 的 db.collection_name.drop()
用于從數(shù)據(jù)庫中刪除集合。如果選定的集合成功刪除,drop()
方法將返回true
,否則返回false
以上這篇老生常談MongoDB數(shù)據(jù)庫基礎(chǔ)操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:- 詳解MongoDB數(shù)據(jù)庫基礎(chǔ)操作及實例
- mongodb數(shù)據(jù)庫基礎(chǔ)知識之連表查詢
- MongoDB數(shù)據(jù)庫插入、更新和刪除操作詳解
- PHP中MongoDB數(shù)據(jù)庫的連接、添加、修改、查詢、刪除等操作實例
- mongodb 數(shù)據(jù)庫操作詳解--創(chuàng)建,切換,刪除
- mongodb 數(shù)據(jù)庫操作--備份 還原 導(dǎo)出 導(dǎo)入
- MongoDB數(shù)據(jù)庫文檔操作方法(必看篇)
- MongoDB模糊查詢操作案例詳解(類關(guān)系型數(shù)據(jù)庫的 like 和 not like)
- mongoDB4.0數(shù)據(jù)庫的操作方法
- mongodb數(shù)據(jù)庫入門學(xué)習(xí)筆記之下載、安裝、啟動、連接操作解析
- MongoDB數(shù)據(jù)庫安裝配置、基本操作實例詳解
- MongoDB數(shù)據(jù)庫基礎(chǔ)操作總結(jié)