您好,登錄后才能下訂單哦!
這篇文章給大家介紹使用java怎么連接mongoDB并進行增刪改查操作,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
在java中使用mongoDB之前,首先需要擁有java連接mongoDB的第三方驅動包(jar包)
<dependencies> <dependency> <groupId>org.mongodb</groupId> <artifactId>mongo-java-driver</artifactId> <version>3.0.4</version> </dependency> </dependencies>
mongoDB jar包
將mongoDB JDBC驅動加入到項目之后,就可以對mongoDB進行操作了。
//連接到 mongodb 服務 MongoClient mongoClient = new MongoClient("localhost", 27017);
這里的 "localhost" 表示連接的服務器地址,27017 為端口號。可以省略 端口號 不寫,系統將默認端口號為 27017。如:
//連接到 mongodb 服務,默認端口號為27017 MongoClient mongoClient = new MongoClient("localhost");
也可以將 服務器地址 和 端口號 都省略,系統默認服務器地址為 "localhost",端口號為 27017。如:
//連接到 mongodb 服務,默認連接到localhost服務器,端口號為27017 MongoClient mongoClient = new MongoClient();
List<ServerAddress> adds = new ArrayList<>(); //ServerAddress()兩個參數分別為 服務器地址 和 端口 ServerAddress serverAddress = new ServerAddress("localhost", 27017); adds.add(serverAddress); List<MongoCredential> credentials = new ArrayList<>(); //MongoCredential.createScramSha1Credential()三個參數分別為 用戶名 數據庫名稱 密碼 MongoCredential mongoCredential = MongoCredential.createScramSha1Credential("username", "databaseName", "password".toCharArray()); credentials.add(mongoCredential); //通過連接認證獲取MongoDB連接 MongoClient mongoClient = new MongoClient(adds, credentials);
ServerAddress()
兩個參數 "localhost" , 27017 分別為 服務器地址 和 端口。
MongoCredential.createScramSha1Credential()
三個參數 "username", "databaseName", "password".toCharArray() 分別為 用戶名 數據庫名稱 密碼。
//連接到數據庫 MongoDatabase mongoDatabase = mongoClient.getDatabase("test");
這里的 "test" 表示數據庫名,若指定的數據庫不存在,mongoDB將會在你第一次插入文檔時創建數據庫。
由于所有連接數據庫操作都需要執行這兩步操作,我們可以將這兩步操作封裝成工具類。
import com.mongodb.MongoClient; import com.mongodb.client.MongoDatabase; //mongodb 連接數據庫工具類 public class MongoDBUtil { //不通過認證獲取連接數據庫對象 public static MongoDatabase getConnect(){ //連接到 mongodb 服務 MongoClient mongoClient = new MongoClient("localhost", 27017); //連接到數據庫 MongoDatabase mongoDatabase = mongoClient.getDatabase("test"); //返回連接數據庫對象 return mongoDatabase; } //需要密碼認證方式連接 public static MongoDatabase getConnect2(){ List<ServerAddress> adds = new ArrayList<>(); //ServerAddress()兩個參數分別為 服務器地址 和 端口 ServerAddress serverAddress = new ServerAddress("localhost", 27017); adds.add(serverAddress); List<MongoCredential> credentials = new ArrayList<>(); //MongoCredential.createScramSha1Credential()三個參數分別為 用戶名 數據庫名稱 密碼 MongoCredential mongoCredential = MongoCredential.createScramSha1Credential("username", "databaseName", "password".toCharArray()); credentials.add(mongoCredential); //通過連接認證獲取MongoDB連接 MongoClient mongoClient = new MongoClient(adds, credentials); //連接到數據庫 MongoDatabase mongoDatabase = mongoClient.getDatabase("test"); //返回連接數據庫對象 return mongoDatabase; } }
mongoDB中的數據都是通過文檔(對應于關系型數據庫表中的一行)保存的,而文檔又保存在集合(對應于關系型數據庫的表)中。
要對數據進行CRUD操作首先要獲取到操作的集合。
//獲取集合 MongoCollection<Document> collection = MongoDBUtil.getConnect().getCollection("user");
這里的 "user" 表示集合的名字,如果指定的集合不存在,mongoDB將會在你第一次插入文檔時創建集合。
要插入文檔首先需要創建文檔對象
//創建文檔 Document document = new Document("name","張三") .append("sex", "男") .append("age", 18);
插入一個文檔,使用 MongoCollection 對象的 insertOne()
方法,該方法接收一個 Document 對象作為要插入的數據
//插入一個文檔 @Test public void insertOneTest(){ //獲取數據庫連接對象 MongoDatabase mongoDatabase = MongoDBUtil.getConnect(); //獲取集合 MongoCollection<Document> collection = mongoDatabase.getCollection("user"); //要插入的數據 Document document = new Document("name","張三") .append("sex", "男") .append("age", 18); //插入一個文檔 collection.insertOne(document); }
插入多個文檔,使用 MongoCollection 對象的 insertMany()
方法,該方法接收一個 數據類型為 Document 的 List 對象作為要插入的數據
//插入多個文檔 @Test public void insertManyTest(){ //獲取數據庫連接對象 MongoDatabase mongoDatabase = MongoDBUtil.getConnect(); //獲取集合 MongoCollection<Document> collection = mongoDatabase.getCollection("user"); //要插入的數據 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); } //插入多個文檔 collection.insertMany(list); }
刪除與篩選器匹配的單個文檔,使用 MongoCollection 對象的 deleteOne()
方法,該方法接收一個數據類型為 Bson 的的對象作為過濾器篩選出需要刪除的文檔。然后刪除第一個。為了便于創建過濾器對象,JDBC驅動程序提供了 Filters 類。
//刪除與篩選器匹配的單個文檔 @Test public void deleteOneTest(){ //獲取數據庫連接對象 MongoDatabase mongoDatabase = MongoDBUtil.getConnect(); //獲取集合 MongoCollection<Document> collection = mongoDatabase.getCollection("user"); //申明刪除條件 Bson filter = Filters.eq("age",18); //刪除與篩選器匹配的單個文檔 collection.deleteOne(filter); }
刪除與篩選器匹配的所有文檔,使用 MongoCollection 對象的 deleteMany()
方法,該方法接收一個數據類型為 Bson 的的對象作為過濾器篩選出需要刪除的文檔。然后刪除所有篩選出的文檔。
//刪除與篩選器匹配的所有文檔 @Test public void deleteManyTest(){ //獲取數據庫連接對象 MongoDatabase mongoDatabase = MongoDBUtil.getConnect(); //獲取集合 MongoCollection<Document> collection = mongoDatabase.getCollection("user"); //申明刪除條件 Bson filter = Filters.eq("age",18); //刪除與篩選器匹配的所有文檔 collection.deleteMany(filter); }
修改單個文檔,使用 MongoCollection 對象的 updateOne()
方法,該方法接收兩個參數,第一個數據類型為 Bson 的過濾器篩選出需要修改的文檔,第二個參數數據類型為 Bson 指定如何修改篩選出的文檔。然后修改過濾器篩選出的第一個文檔。
//修改單個文檔 @Test public void updateOneTest(){ //獲取數據庫連接對象 MongoDatabase mongoDatabase = MongoDBUtil.getConnect(); //獲取集合 MongoCollection<Document> collection = mongoDatabase.getCollection("user"); //修改過濾器 Bson filter = Filters.eq("name", "張三"); //指定修改的更新文檔 Document document = new Document("$set", new Document("age", 100)); //修改單個文檔 collection.updateOne(filter, document); }
修改多個文檔,使用 MongoCollection 對象的 updateMany()
方法,該方法接收兩個參數,第一個數據類型為 Bson 的過濾器篩選出需要修改的文檔,第二個參數數據類型為 Bson 指定如何修改篩選出的文檔。然后修改過濾器篩選出的所有文檔。
//修改多個文檔 @Test public void updateManyTest(){ //獲取數據庫連接對象 MongoDatabase mongoDatabase = MongoDBUtil.getConnect(); //獲取集合 MongoCollection<Document> collection = mongoDatabase.getCollection("user"); //修改過濾器 Bson filter = Filters.eq("name", "張三"); //指定修改的更新文檔 Document document = new Document("$set", new Document("age", 100)); //修改多個文檔 collection.updateMany(filter, document); }
使用 MongoCollection 對象的 find()
方法,該方法有多個重載方法,可以使用不帶參數的 find()
方法查詢集合中的所有文檔,也可以通過傳遞一個 Bson 類型的 過濾器查詢符合條件的文檔。這幾個重載方法均返回一個 FindIterable 類型的對象,可通過該對象遍歷出查詢到的所有文檔。
查找集合中的所有文檔
//查找集合中的所有文檔 @Test public void findTest(){ //獲取數據庫連接對象 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(){ //獲取數據庫連接對象 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()
方法取出查詢到的第一個文檔
//取出查詢到的第一個文檔 @Test public void findTest(){ //獲取數據庫連接對象 MongoDatabase mongoDatabase = MongoDBUtil.getConnect(); //獲取集合 MongoCollection<Document> collection = mongoDatabase.getCollection("user"); //查找集合中的所有文檔 FindIterable findIterable = collection.find(); //取出查詢到的第一個文檔 Document document = (Document) findIterable.first(); //打印輸出 System.out.println(document); }
Java的特點有哪些 1.Java語言作為靜態面向對象編程語言的代表,實現了面向對象理論,允許程序員以優雅的思維方式進行復雜的編程。 2.Java具有簡單性、面向對象、分布式、安全性、平臺獨立與可移植性、動態性等特點。 3.使用Java可以編寫桌面應用程序、Web應用程序、分布式系統和嵌入式系統應用程序等。
關于使用java怎么連接mongoDB并進行增刪改查操作就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。