一:MonoDB的簡單介紹
MongoDB是一個介於關系型數據庫與非關系型數據庫中間的數據庫,是使用C++進行編寫的,他的優點是在支持的查詢格式特別的強大,可以進行存儲比較復雜的數據類型,支持建立索引
二:下載
官方地址:https://www.mongodb.com/
本教程下載 3.4版本:http://downloads.mongodb.org/win32/mongodb-win32-x86_64-2008plus-ssl-v3.4-latest-signed.msi
三:安裝與啟動服務
1,對MongoDB進行安裝之后,在bin的同級目錄下創建 數據庫路徑(data目錄),日志路徑(logs目錄)和 日志文件(mongo.log文件)
2,創建並編輯配置文件:mongo.conf
#數據庫路徑 dbpath=d:\MongoDB\Server\3.4\data #日志輸出文件路徑 logpath=d:\MongoDB\Server\3.4\logs\mongo.log #錯誤日志采用追加模式 logappend=true #啟用日志文件,默認啟用 journal=true #這個選項可以過濾掉一些無用的日志信息,若需要調試使用請設置為false quiet=true #端口號 默認為27017 port=27017
3,進入bin目錄下,使用管理員進入命令行窗口,執行下面的命令進行安裝
mongod.exe --config " xxxx/mongo.conf(路徑) " --install
4,執行對應的命令
net start MongoDB #啟動MongoDB net stop MongoDB #關閉MongoDB “...../mongod.exe” --remove #移除MongoDB
5,驗證是否啟動成功
訪問:http://localhost:27017 查詢MongoDB的頁面
四:對於客戶端的安裝:
目前對於MongoDB 的客戶端有很多可以自行下載,我推薦的是nosqlbooster,下載地址:https://nosqlbooster.com/downloads
五:java對MongoDB的簡單使用
1,服務的連接格式
mongodb://[username:password@]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]]
對應的名詞解釋:
mongodb:// 固定前綴
username:賬號,可不填
password:密碼,可不填
host:主機名或ip地址,只有host主機名為必填項。
port:端口,可不填,默認27017
/database:連接某一個數據庫
?options:連接參數,key/value對
示例:
1,mongodb://localhost 連接本地數據庫27017端口 2,mongodb://root:itcast@localhost 使用用戶名root密碼為itcast連接本地數據庫27017端口 3,mongodb://localhost,localhost:27018,localhost:27019,連接三台主從服務器,端口為27017、27018、27019
2,添加依賴
<dependency> <groupId>org.mongodb</groupId> <artifactId>mongo-java-driver</artifactId> <version>3.4.3</version> </dependency>
3,代碼測試連接
//測試連接 @Test public void testConnect(){ //創建客戶端 MongoClient mongoClient = new MongoClient("localhost", 27017); //采用連接字符串簡歷連接 // MongoClientURI connecting = new MongoClientURI("mongodb://localhost:27017/test"); //記得數據庫的名字 //MongoClient client = new MongoClient(connecting); MongoDatabase database = mongoClient.getDatabase("test");//獲取數據庫 MongoCollection<Document> collection = database.getCollection("student"); //獲取對應的表 Document document = collection.find().first(); //獲取對應的行 String json = document.toJson(); System.out.println(json); }
注意:在使用URI進行連接的時候,加上數據庫的名字,如果出現了如下的錯誤,【MongoCommandException: Command failed with error 18: 'Authentication failed.】,此時請檢查連接的地址以及用戶是否是該數據庫所屬的用戶,在MongoDB中,一個用戶對應一個庫,在連接時應寫對應的
六:MongoDB涉及命令
#數據庫以及集合相關 1,show dbs 查詢全部數據庫 2,use dbbase_name 切換或者創建數據庫 3,db.dropDatabase() 刪除數據庫,要先切換到對應的數據庫下 4,db.createCollection(name,options), 5,db.collectionName.drop() 刪除集合 6,db.collectionName.insert({"key": "value"}) 對集合添加數據 7,db.collectionName.update( {更新條件},{更新的內容},選項 ) 8,db.collectionName.remove({刪除條件})根據條件進行刪除文檔 9,db.collectionName.remove() 刪除所有的文檔 10,db.collectionName.find({查詢條件}),沒有條件就是查詢所有的文檔 11,db.collectionName.find({查詢條件},{要顯示的字段,需要顯示的是1,不需要顯示的是0,不用加雙引號}),投影查詢 #用戶相關 1,先切換到對應的數據庫下:use databaseName 2,sb.createUser({ user: "username", pwd:"密碼", roles:[ { role:"角色",db:"數據庫名字" } ] }) show users: 查詢用戶 db.dropUser(“ 用戶名 ”) 刪除用戶 db.updateUser("用戶名",{roles:[{role:"角色",db:“數據庫角色”}]}) 修改用戶信息 db.changeUserPassword("用戶名",“新的密碼”)