java連接mongoDB并進(jìn)行增刪改查操作實(shí)例詳解
本文實(shí)例講述了java連接mongoDB并進(jìn)行增刪改查操作。分享給大家供大家參考,具體如下:
1、安裝 MongoDB JDBC驅(qū)動(dòng)程序
在java中使用mongoDB之前,首先需要擁有java連接mongoDB的第三方驅(qū)動(dòng)包(jar包)
1)maven項(xiàng)目可通過在pom.xml中添加依賴
<dependencies> <dependency> <groupId>org.mongodb</groupId> <artifactId>mongo-java-driver</artifactId> <version>3.0.4</version> </dependency> </dependencies>
2)非maven項(xiàng)目jar包下載地址:
2、連接數(shù)據(jù)庫
將mongoDB JDBC驅(qū)動(dòng)加入到項(xiàng)目之后,就可以對mongoDB進(jìn)行操作了。
1)不通過認(rèn)證連接mongoDB服務(wù)
//連接到 mongodb 服務(wù)
MongoClient mongoClient = new MongoClient("localhost", 27017);
這里的 "localhost" 表示連接的服務(wù)器地址,27017 為端口號。可以省略 端口號 不寫,系統(tǒng)將默認(rèn)端口號為 27017。如:
//連接到 mongodb 服務(wù),默認(rèn)端口號為27017
MongoClient mongoClient = new MongoClient("localhost");
也可以將 服務(wù)器地址 和 端口號 都省略,系統(tǒng)默認(rèn)服務(wù)器地址為 "localhost",端口號為 27017。如:
//連接到 mongodb 服務(wù),默認(rèn)連接到localhost服務(wù)器,端口號為27017 MongoClient mongoClient = new MongoClient();
2)通過認(rèn)證連接mongoDB服務(wù)
List<ServerAddress> adds = new ArrayList<>();
//ServerAddress()兩個(gè)參數(shù)分別為 服務(wù)器地址 和 端口
ServerAddress serverAddress = new ServerAddress("localhost", 27017);
adds.add(serverAddress);
List<MongoCredential> credentials = new ArrayList<>();
//MongoCredential.createScramSha1Credential()三個(gè)參數(shù)分別為 用戶名 數(shù)據(jù)庫名稱 密碼
MongoCredential mongoCredential = MongoCredential.createScramSha1Credential("username", "databaseName", "password".toCharArray());
credentials.add(mongoCredential);
//通過連接認(rèn)證獲取MongoDB連接
MongoClient mongoClient = new MongoClient(adds, credentials);
ServerAddress()兩個(gè)參數(shù) "localhost" , 27017 分別為 服務(wù)器地址 和 端口。
MongoCredential.createScramSha1Credential()三個(gè)參數(shù) "username", "databaseName", "password".toCharArray() 分別為 用戶名 數(shù)據(jù)庫名稱 密碼。
3)連接到數(shù)據(jù)庫
//連接到數(shù)據(jù)庫
MongoDatabase mongoDatabase = mongoClient.getDatabase("test");
這里的 "test" 表示數(shù)據(jù)庫名,若指定的數(shù)據(jù)庫不存在,mongoDB將會(huì)在你第一次插入文檔時(shí)創(chuàng)建數(shù)據(jù)庫。
4)封裝成工具類
由于所有連接數(shù)據(jù)庫操作都需要執(zhí)行這兩步操作,我們可以將這兩步操作封裝成工具類。
import com.mongodb.MongoClient;
import com.mongodb.client.MongoDatabase;
//mongodb 連接數(shù)據(jù)庫工具類
public class MongoDBUtil {
//不通過認(rèn)證獲取連接數(shù)據(jù)庫對象
public static MongoDatabase getConnect(){
//連接到 mongodb 服務(wù)
MongoClient mongoClient = new MongoClient("localhost", 27017);
//連接到數(shù)據(jù)庫
MongoDatabase mongoDatabase = mongoClient.getDatabase("test");
//返回連接數(shù)據(jù)庫對象
return mongoDatabase;
}
//需要密碼認(rèn)證方式連接
public static MongoDatabase getConnect2(){
List<ServerAddress> adds = new ArrayList<>();
//ServerAddress()兩個(gè)參數(shù)分別為 服務(wù)器地址 和 端口
ServerAddress serverAddress = new ServerAddress("localhost", 27017);
adds.add(serverAddress);
List<MongoCredential> credentials = new ArrayList<>();
//MongoCredential.createScramSha1Credential()三個(gè)參數(shù)分別為 用戶名 數(shù)據(jù)庫名稱 密碼
MongoCredential mongoCredential = MongoCredential.createScramSha1Credential("username", "databaseName", "password".toCharArray());
credentials.add(mongoCredential);
//通過連接認(rèn)證獲取MongoDB連接
MongoClient mongoClient = new MongoClient(adds, credentials);
//連接到數(shù)據(jù)庫
MongoDatabase mongoDatabase = mongoClient.getDatabase("test");
//返回連接數(shù)據(jù)庫對象
return mongoDatabase;
}
}
3、對數(shù)據(jù)庫進(jìn)行CRUD
mongoDB中的數(shù)據(jù)都是通過文檔(對應(yīng)于關(guān)系型數(shù)據(jù)庫表中的一行)保存的,而文檔又保存在集合(對應(yīng)于關(guān)系型數(shù)據(jù)庫的表)中。
1)獲取集合
要對數(shù)據(jù)進(jìn)行CRUD操作首先要獲取到操作的集合。
//獲取集合
MongoCollection<Document> collection = MongoDBUtil.getConnect().getCollection("user");
這里的 "user" 表示集合的名字,如果指定的集合不存在,mongoDB將會(huì)在你第一次插入文檔時(shí)創(chuàng)建集合。
2)創(chuàng)建文檔
要插入文檔首先需要?jiǎng)?chuàng)建文檔對象
//創(chuàng)建文檔
Document document = new Document("name","張三")
.append("sex", "男")
.append("age", 18);
3)插入文檔
插入一個(gè)文檔,使用 MongoCollection 對象的 insertOne() 方法,該方法接收一個(gè) Document 對象作為要插入的數(shù)據(jù)
//插入一個(gè)文檔
@Test
public void insertOneTest(){
//獲取數(shù)據(jù)庫連接對象
MongoDatabase mongoDatabase = MongoDBUtil.getConnect();
//獲取集合
MongoCollection<Document> collection = mongoDatabase.getCollection("user");
//要插入的數(shù)據(jù)
Document document = new Document("name","張三")
.append("sex", "男")
.append("age", 18);
//插入一個(gè)文檔
collection.insertOne(document);
}
插入多個(gè)文檔,使用 MongoCollection 對象的 insertMany() 方法,該方法接收一個(gè) 數(shù)據(jù)類型為 Document 的 List 對象作為要插入的數(shù)據(jù)
//插入多個(gè)文檔
@Test
public void insertManyTest(){
//獲取數(shù)據(jù)庫連接對象
MongoDatabase mongoDatabase = MongoDBUtil.getConnect();
//獲取集合
MongoCollection<Document> collection = mongoDatabase.getCollection("user");
//要插入的數(shù)據(jù)
List<Document> list = new ArrayList<>();
for(int i = 1; i <= 3; i++) {
Document document = new Document("name", "張三")
.append("sex", "男")
.append("age", 18);
list.add(document);
}
//插入多個(gè)文檔
collection.insertMany(list);
}
4)刪除文檔
刪除與篩選器匹配的單個(gè)文檔,使用 MongoCollection 對象的 deleteOne() 方法,該方法接收一個(gè)數(shù)據(jù)類型為 Bson 的的對象作為過濾器篩選出需要?jiǎng)h除的文檔。然后刪除第一個(gè)。為了便于創(chuàng)建過濾器對象,JDBC驅(qū)動(dòng)程序提供了 Filters 類。
//刪除與篩選器匹配的單個(gè)文檔
@Test
public void deleteOneTest(){
//獲取數(shù)據(jù)庫連接對象
MongoDatabase mongoDatabase = MongoDBUtil.getConnect();
//獲取集合
MongoCollection<Document> collection = mongoDatabase.getCollection("user");
//申明刪除條件
Bson filter = Filters.eq("age",18);
//刪除與篩選器匹配的單個(gè)文檔
collection.deleteOne(filter);
}
刪除與篩選器匹配的所有文檔,使用 MongoCollection 對象的 deleteMany() 方法,該方法接收一個(gè)數(shù)據(jù)類型為 Bson 的的對象作為過濾器篩選出需要?jiǎng)h除的文檔。然后刪除所有篩選出的文檔。
//刪除與篩選器匹配的所有文檔
@Test
public void deleteManyTest(){
//獲取數(shù)據(jù)庫連接對象
MongoDatabase mongoDatabase = MongoDBUtil.getConnect();
//獲取集合
MongoCollection<Document> collection = mongoDatabase.getCollection("user");
//申明刪除條件
Bson filter = Filters.eq("age",18);
//刪除與篩選器匹配的所有文檔
collection.deleteMany(filter);
}
5)修改文檔
修改單個(gè)文檔,使用 MongoCollection 對象的 updateOne() 方法,該方法接收兩個(gè)參數(shù),第一個(gè)數(shù)據(jù)類型為 Bson 的過濾器篩選出需要修改的文檔,第二個(gè)參數(shù)數(shù)據(jù)類型為 Bson 指定如何修改篩選出的文檔。然后修改過濾器篩選出的第一個(gè)文檔。
//修改單個(gè)文檔
@Test
public void updateOneTest(){
//獲取數(shù)據(jù)庫連接對象
MongoDatabase mongoDatabase = MongoDBUtil.getConnect();
//獲取集合
MongoCollection<Document> collection = mongoDatabase.getCollection("user");
//修改過濾器
Bson filter = Filters.eq("name", "張三");
//指定修改的更新文檔
Document document = new Document("$set", new Document("age", 100));
//修改單個(gè)文檔
collection.updateOne(filter, document);
}
修改多個(gè)文檔,使用 MongoCollection 對象的 updateMany() 方法,該方法接收兩個(gè)參數(shù),第一個(gè)數(shù)據(jù)類型為 Bson 的過濾器篩選出需要修改的文檔,第二個(gè)參數(shù)數(shù)據(jù)類型為 Bson 指定如何修改篩選出的文檔。然后修改過濾器篩選出的所有文檔。
//修改多個(gè)文檔
@Test
public void updateManyTest(){
//獲取數(shù)據(jù)庫連接對象
MongoDatabase mongoDatabase = MongoDBUtil.getConnect();
//獲取集合
MongoCollection<Document> collection = mongoDatabase.getCollection("user");
//修改過濾器
Bson filter = Filters.eq("name", "張三");
//指定修改的更新文檔
Document document = new Document("$set", new Document("age", 100));
//修改多個(gè)文檔
collection.updateMany(filter, document);
}
6)查詢文檔
使用 MongoCollection 對象的 find() 方法,該方法有多個(gè)重載方法,可以使用不帶參數(shù)的 find() 方法查詢集合中的所有文檔,也可以通過傳遞一個(gè) Bson 類型的 過濾器查詢符合條件的文檔。這幾個(gè)重載方法均返回一個(gè) FindIterable 類型的對象,可通過該對象遍歷出查詢到的所有文檔。
查找集合中的所有文檔
//查找集合中的所有文檔
@Test
public void findTest(){
//獲取數(shù)據(jù)庫連接對象
MongoDatabase mongoDatabase = MongoDBUtil.getConnect();
//獲取集合
MongoCollection<Document> collection = mongoDatabase.getCollection("user");
//查找集合中的所有文檔
FindIterable findIterable = collection.find();
MongoCursor cursor = findIterable.iterator();
while (cursor.hasNext()) {
System.out.println(cursor.next());
}
}
指定查詢過濾器查詢
//指定查詢過濾器查詢
@Test
public void FilterfindTest(){
//獲取數(shù)據(jù)庫連接對象
MongoDatabase mongoDatabase = MongoDBUtil.getConnect();
//獲取集合
MongoCollection<Document> collection = mongoDatabase.getCollection("user");
//指定查詢過濾器
Bson filter = Filters.eq("name", "張三");
//指定查詢過濾器查詢
FindIterable findIterable = collection.find(filter);
MongoCursor cursor = findIterable.iterator();
while (cursor.hasNext()) {
System.out.println(cursor.next());
}
}
可通過 first() 方法取出查詢到的第一個(gè)文檔
//取出查詢到的第一個(gè)文檔
@Test
public void findTest(){
//獲取數(shù)據(jù)庫連接對象
MongoDatabase mongoDatabase = MongoDBUtil.getConnect();
//獲取集合
MongoCollection<Document> collection = mongoDatabase.getCollection("user");
//查找集合中的所有文檔
FindIterable findIterable = collection.find();
//取出查詢到的第一個(gè)文檔
Document document = (Document) findIterable.first();
//打印輸出
System.out.println(document);
}
4、總結(jié)
到這里,java對mongoDB的一些基本操作就介紹完了。實(shí)現(xiàn)的步驟為:添加驅(qū)動(dòng)==>連接到服務(wù)==>連接到數(shù)據(jù)庫==>選擇集合==>對集合進(jìn)行CRUD操作。
更多關(guān)于java相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java使用JDBC操作數(shù)據(jù)庫技巧總結(jié)》、《Java+MySQL數(shù)據(jù)庫程序設(shè)計(jì)總結(jié)》、《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java文件與目錄操作技巧匯總》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設(shè)計(jì)有所幫助。
相關(guān)文章
java中hashmap容量的初始化實(shí)現(xiàn)
這篇文章主要介紹了java中hashmap容量的初始化實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
淺談Java?abstract關(guān)鍵字不能和哪些關(guān)鍵字共存
本文主要介紹了Java?abstract關(guān)鍵字不能和哪些關(guān)鍵字共存,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-10-10
Java?數(shù)據(jù)結(jié)構(gòu)與算法系列精講之棧
棧(stack)又名堆棧,它是一種運(yùn)算受限的線性表。限定僅在表尾進(jìn)行插入和刪除操作的線性表。這一端被稱為棧頂,相對地,把另一端稱為棧底,棧是基礎(chǔ)中的基礎(chǔ),如果你還沒掌握透徹就來接著往下看吧2022-02-02
Java虛擬機(jī)類加載器之雙親委派機(jī)制模型案例
這篇文章主要介紹了Java虛擬機(jī)類加載器之雙親委派機(jī)制模型案例,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
SpringBoot2開啟Actuator端點(diǎn)監(jiān)控的方法
這篇文章主要介紹了SpringBoot2開啟Actuator端點(diǎn)監(jiān)控的相關(guān)資料,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06
Springboot 實(shí)現(xiàn)數(shù)據(jù)庫備份還原的方法
這篇文章主要介紹了Springboot 實(shí)現(xiàn)數(shù)據(jù)庫備份還原的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09
java中用數(shù)組實(shí)現(xiàn)環(huán)形隊(duì)列的示例代碼
這篇文章主要介紹了java中用數(shù)組實(shí)現(xiàn)環(huán)形隊(duì)列的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
基于Struts2實(shí)現(xiàn)防止表單重復(fù)提交
這篇文章主要介紹了基于Struts2實(shí)現(xiàn)防止表單重復(fù)提交,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10

