一:MonoDB的簡單介紹 MongoDB是一個介於關係型資料庫與非關係型資料庫中間的資料庫,是使用C++進行編寫的,他的優點是在支持的查詢格式特別的強大,可以進行存儲比較複雜的數據類型,支持建立索引 二:下載 官方地址:https://www.mongodb.com/ 本教程下載 3.4版本:ht ...
一: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 #啟用日誌文件,預設啟用 /ˈdʒɜːnl/ 日誌,日記 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、270192,添加依賴
<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("用戶名",“新的密碼”)