MongoDB的入門使用


一: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("用戶名",“新的密碼”)

  

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM