摘要:我們后續的數據庫操作需要再開一個。接下去我們就進入了的語法環境下,可以輸入命令進行數據庫的操作。在上述命令當中,如果數據庫與集合名均為不存在的,則一并完成了新建的操作。
mongodb是文檔型數據庫,其官網地址為 https://www.mongodb.com/。我們在官網上下載該軟件包,并完成安裝。如我們可以設置安裝路徑為D:MongoDBmongodb。我們在完成安裝之后,可以看到在該目錄的bin文件夾下有如下文件:
接下去我們配置環境變量,為了能在任意目錄下都能運行bin這個文件夾下的應用程序。我們在環境變量的用戶變量當中新建一個名為Mongodb的變量,其變量值為D:MongoDBmongodbin。接下去編輯用戶變量當中的PATH變量值,在其值后面加上;%Mongodb%;。最后確定關閉完成了環境變量的配置。接下去在cmd當中,鍵入命令-> mongo,顯示如下結果,則說明安裝和配置成功。
一、Mongodb數據庫的開機與連接這里我們可以看到可以正確顯示我們安裝的mongodb的版本號,在此顯示連接失敗是因為我們還沒進行數據庫開機的操作。
由于mongodb為文檔型的數據庫,它不同于mysql等數據庫,它的數據庫真實可見,與我們本機上的物理文件一一對應。故我們需要先建立一個文件夾,作為數據庫真實存放的位置。比如我們在D盤根目錄下新建一個名為mongo的文件夾,則該數據庫文檔所在文件夾的絕對物理路徑為D:mongo。
接下去我們打開cmd,輸入開機命令-> mongod --dbpath D:mongo。此時可以看到控制臺在最后一行輸出waiting for connections on port 27017,則說明此時數據庫完成了開機操作。
此時在我們新建的mongo文件夾下多了如下所示的默認文件:
在開機命令當中--dbpath用于選擇數據庫文檔所在的文件夾,是數據庫真實存放的位置。在該文件夾下,所有以.ns為后綴名的文件都為數據庫,即mongodb中數據庫真實可見,有物理文件與數據庫一一對應。
在完成數據庫的開機操作之后,我們一定要讓這個cmd面板保持上圖所示的狀態,不能關閉,不能退出程序。一旦該cmd出現問題,我們的數據庫就自動關閉了。我們后續的數據庫操作需要再開一個cmd。
接下去我們再開一個cmd,輸入命令-> mongo 用于連接數據庫。當顯示如下所示,則說明數據庫連接成功。
接下去我們就進入了mongodb的語法環境下,可以輸入命令進行數據庫的操作。
我們用命令-> show dbs來顯示當前所有的數據庫。(現在只有一些系統默認的數據庫文件,這些系統自帶的文件,我們不做任何操作)
我們用命令-> use test來表示使用某個數據庫,當use一個不存在的數據庫則表示新建。之后再用命令-> db來查看當前所在的數據庫。我們在完成test數據庫的新建之后,用-> show dbs查看現在所有的數據庫,仍然看不到我們新建的那個數據庫,說明我們想把這個數據庫新建成功,則必須往里面插入一條數據。
mongodb的某個數據庫由很多個集合(collection)組成,集合類似于mysql數據庫當中數據表的概念,而每一個集合又由很多個文檔(document)構成。每一個文檔都是一個json對象,文檔類似于mysql數據表當中字段的概念。數據庫當中不能直接插入數據,只能往該數據庫的某個指定集合當中插入數據,集合不需要新建,一旦我們往某個集合當中插入數據,就相當于新建了這個集合,并且該集合當中也有了對應的數據。
我們在cmd當中用命令-> db來確定當前所在的數據庫為test,接下去用命令-> db.student.insert()往該集合當中插入一個json對象。這句操作完成了在test數據庫中student這個集合的創建與一條文檔數據的插入。接下去可用命令-> show collections來列出當前這個數據庫當中所有的集合(其中system.indexes為系統默認的集合,不做任何處理)。用命令-> db.student.find()來列出當前這個數據庫中student這個集合當中所有的文檔數據。如下圖所示:
二、MongoVUE的使用此時可以看到mongo這個文件夾下多了test.0與test.ns這兩個文件。每一條文檔數據都為一個json數據,插入文檔時應該讓其符合嚴格的json語法。數據庫當中每一條文檔數據都會被分配一個唯一的_id屬性值。
MongoVUE是Mongodb的一款可視化管理工具。我們在完成安裝之后,手動啟動MongoVUE.exe進入其管理界面。在第一次使用時,在彈出框Connect to Mongo Database當中選擇新建,填寫如下信息:
我們在server當中填寫127.0.0.1,表示連接本地數據庫,當輸入指定的IP地址還可用于連接遠程的數據庫。而port端口號為默認的27017即可。保存后選擇連接即可。
我們一定要在完成數據庫的開機操作之后,才可以使用MongoVUE對該數據庫進行連接,否則會顯示連接失敗。
在完成連接之后我們可以看到:
在該面板的左側邊欄可以看到我們當前所有的數據庫,其中admin與local為系統默認數據庫,我們不對其做任何處理。其中test是我們新建的數據庫,在其內部的Collections的分支下可以看到該數據庫下所有的集合,選中student這個集合(不用對其再展開)右鍵選擇View則可以在右側面板看到有三種視圖可供選擇,可以顯示這個集合當中所有的文檔及數據。
三、Mongodb數據庫的增刪改查操作我們一般在cmd當中進行數據庫的增刪改查的操作,在可視化面板當中查看數據庫當中數據的存儲情況,即在命令行當中進行控制操作,在可視化工具當中進行驗證。由于可視化工具不能自動刷新,我們在完成操作之后,需要點擊面板左側的Refresh刷新,然后再選中某個集合右鍵View才可以查看最新的文檔數據。
我們之前操作過往test數據庫的student集合當中插入一條文檔數據,但是用這種方式在控制臺當中完成數據導入效率太低。我們一般把一個集合當中的文檔數據用json文件的形式在外部編輯器當中編輯完成之后,統一全部導入數據庫的某個集合當中。
在進行導入操作時,要再開一個cmd,然后用命令-> mongoimport --db 數據庫名 --collection 集合名 --drop --file json文件的絕對物理路徑來進行導入操作。
在上述命令當中,如果數據庫與集合名均為不存在的,則一并完成了新建的操作。我們在外部編輯器當中完成json文件的編輯,后綴名為.json的文件必須能嚴格遵守json格式,key值必須能加雙引號,value值若為字符串類型,也必須加雙引號。直接把該文件拖進cmd當中,則自動顯示該json文件的絕對物理地址。--drop表示為在往該集合當中導入數據之前先清空這個集合。
在完成數據的導入之后,我們回到之前連接數據庫的那個cmd當中,用命令-> db來查看當前的使用的數據庫為test,接下去用命令-> db.student.find()來對當前這個數據庫的student集合進行查詢操作。若find方法當中沒有參數則列出該集合當中所有的文檔對象。
可以在find方法當中傳入一個json對象(這里同樣需要遵循嚴格的json語法)表示查詢條件。如果有多個條件則在該對象當中,用逗號相隔的鍵值對表示查詢條件之間且的關系。若找到了則輸出對應的文檔,若沒找到則不輸出結果,也不會報錯。
我們給查詢對象的某個屬性值加上{$gt:}表示大于符號,{$lt:}表示小于符號。如鍵入命令-> db.student.find({"score.Math":{$gt:74}})表示查詢出數學成績大于74分的文檔對象。
我們在查詢對象當中加上$or:[]表示在該數組當中的每一個查詢條件之間為或的關系,每一個查詢條件用一個json對象來表示。如鍵入命令-> db.student.find({$or:[{"age":9},{"score.Math":70}]})表示查詢出年齡為9歲或數學成績為70分的文檔對象。
我們可以在調用find方法查詢之后,調用sort()方法對查詢結果進行排序操作。屬性值為1代表為升序排列,屬性值為-1則代表為降序排列。如鍵入命令-> db.student.find().sort({"score.Math":1,"age":-1})表示查詢出該集合當中所有的文檔數據,先根據數學成績升序排列,如果數學成績一致,則根據年齡進行逆序排列。(當有多個排序條件時,則按順序確定排序條件的優先級)
鍵入命令-> db.dropDatabase()即可刪除當前這個數據庫。鍵入命令-> db.student.drop()即可刪除當前這個數據庫當中student這個集合。使用命令-> db.student.remove()當中傳入一個查詢對象則可以把該集合當中符合該查詢條件的文檔都刪去,如-> db.student.remove({"age":9})則會刪調年齡為9的所有文檔,如果加上{justOne:true}則只刪第一個匹配上的文檔。如-> db.student.remove({"age":9},{justOne:true})。使用-> db.student.remove({})可以刪除該集合當中的所有文檔,達到清空該集合的目的,此時必須能傳入一個空對象才行。
我們使用命令->db.student.update()方法進行文檔修改操作。第一個參數對象表示查詢條件,第二個參數對象為修改的條件。如鍵入命令->db.student.update({"name":"xiaohong"},{$set:{"age":18}})則把名字為小紅的文檔當中的年齡改為18。當第一個查詢條件匹配上多條文檔時,默認只對第一條文檔數據進行修改,如果想要批量修改,則要加上{multi:true},即->db.student.update({"name":"xiaohong"},{$set:{"age":18}},{multi:true})。
如果沒有$set這個關鍵字,則代表替換文檔。如->db.student.update({"name":"xiaohong"},{"age":18}),則表示把名字為小紅這個文檔全部替換為{"age":18}。
使用命令-> db.student.stats().count或者-> db.student.find().count()均可顯示出當前數據庫的student這個集合當中文檔對象的總數。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/19130.html
摘要:安裝全過程環境基本情況我是在電腦下安裝的系統位,這個也是導致我安裝的時候出現異常提示,原因可能是的版本是位的,我應該再找一個位的,但事實上我找不到。 簡述 之前講了一些關于MongoDB的知識,出人意料的受歡迎,也讓我很吃驚,所以今天打算分享一些我在自己計算機的虛擬機的centos系統下安裝MongoDB的經歷,希望感興趣的你們在安裝MongoDB的時候出現問題可以來看看我是怎么安裝的...
摘要:安裝全過程環境基本情況我是在電腦下安裝的系統位,這個也是導致我安裝的時候出現異常提示,原因可能是的版本是位的,我應該再找一個位的,但事實上我找不到。 簡述 之前講了一些關于MongoDB的知識,出人意料的受歡迎,也讓我很吃驚,所以今天打算分享一些我在自己計算機的虛擬機的centos系統下安裝MongoDB的經歷,希望感興趣的你們在安裝MongoDB的時候出現問題可以來看看我是怎么安裝的...
摘要:安裝全過程環境基本情況我是在電腦下安裝的系統位,這個也是導致我安裝的時候出現異常提示,原因可能是的版本是位的,我應該再找一個位的,但事實上我找不到。 簡述 之前講了一些關于MongoDB的知識,出人意料的受歡迎,也讓我很吃驚,所以今天打算分享一些我在自己計算機的虛擬機的centos系統下安裝MongoDB的經歷,希望感興趣的你們在安裝MongoDB的時候出現問題可以來看看我是怎么安裝的...
閱讀 2373·2021-11-18 10:07
閱讀 2330·2021-09-22 15:59
閱讀 3088·2021-08-23 09:42
閱讀 2287·2019-08-30 15:44
閱讀 1201·2019-08-29 15:06
閱讀 2324·2019-08-29 13:27
閱讀 1224·2019-08-29 13:21
閱讀 1423·2019-08-29 13:13