Java访问MongoDB

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介: Java访问MongoDB

pom.xml

代码语言:javascript

复制

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>mongoDB</groupId>
  <artifactId>mongoDB</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>17</maven.compiler.source>
    <maven.compiler.target>17</maven.compiler.target>
<maven-compiler-plugin-version>3.8.1</maven-compiler-plugin-version>
  </properties>
  
<dependencies>
<dependency>
      <groupId>org.mongodb</groupId>
      <artifactId>mongo-java-driver</artifactId>
      <version>3.12.10</version>
</dependency>
<dependency>
      <groupId>org.mongodb</groupId>
      <artifactId>mongodb-driver-sync</artifactId>
      <version>4.5.0</version>
</dependency>
<dependency>  
      <groupId>org.assertj</groupId>  
      <artifactId>assertj-core</artifactId>  
      <version>3.21.0</version> <!-- 使用最新版本 -->  
      <scope>test</scope>  
</dependency>
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter</artifactId>
<version>5.8.2</version>
<scope>test</scope>
</dependency>
</dependencies>
</project>

链接MongoDB Java实现

代码语言:javascript

复制

package mongoDB;
           
import com.mongodb.MongoClient;
import com.mongodb.client.FindIterable;
import com.mongodb.MongoClientURI;
import com.mongodb.client.MongoDatabase;
import com.mongodb.client.model.Filters;
import com.mongodb.client.model.InsertOneModel;
import com.mongodb.client.model.WriteModel;    
import com.mongodb.client.result.DeleteResult;
import com.mongodb.client.result.UpdateResult;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoCursor;
import org.bson.Document;
import org.bson.conversions.Bson;
           
import java.util.ArrayList;
import java.util.List;
           
public class MongoDB {
    // MongoDB服务器的连接URI
    public static  String uri = "mongodb://192.168.31.184:27017";
    // 创建MongoClient实例
    public static MongoClientURI clientURI = new MongoClientURI(uri);
    public MongoClient mongoClient = new MongoClient(clientURI);     
       
    public MongoDatabase connect(String dbname) {    
        // 连接成功,可以进行数据库操作
        System.out.println("Connected to MongoDB");
        // 获取数据库实例
        MongoDatabase database = mongoClient.getDatabase(dbname);
        return database;
    }
    
    public void disconnect() {
           // 关闭连接
           this.mongoClient.close();
    }
    
    public MongoCollectiongetCollection(MongoDatabase database,String mycollection) {    
    
        // 获取集合实例
        MongoCollection collection = database.getCollection(mycollection);    
        return collection;
    }
    
    public void insertOneDocument(String key1,String value1,String key2,int value2,MongoCollectioncollection) {
            // 插入单条文档
        Document document = new Document(key1, value1)
               .append(key2, value2);
               collection.insertOne(document);
    }
    
    public void insertManyDocument(String[][] values,MongoCollectioncollection) {          
    
           // 创建多个文档列表
           List documents = new ArrayList<>();
           for(int i=0;i
                  documents.add(new Document("name", values[i][0]).append("age", Integer.parseInt(values[i][1])));    
           }
        // 创建插入模型列表
        List     <WriteModel> insertManyModels = new ArrayList<>();</WriteModel
        documents.forEach(doc -> insertManyModels.add(new InsertOneModel<>(doc)));
           
        // 插入多条记录
        collection.insertMany(documents);
    }
    
    public MongoCursorsearchDocument(String key,String value,MongoCollectioncollection) {
           // 根据关键字查询文档
           Document query = new Document(key, value);
           MongoCursor cursor = collection.find(query).iterator();
           return cursor;    
    }
    
    public FindIterablefuzzyQuery(String key,String value,MongoCollectioncollection) {
           Bson eq = Filters.regex(key, value);
           FindIterableiterable = collection.find(eq);
           return iterable;
    }
    
    public FindIterableViewAllDocument(MongoCollectioncollection) {
       //显示所有的文档
       FindIterable iterable = collection.find();
       return iterable;
    }
    
    public UpdateResult updateOneDocument(String key_filter,String value_filter,String key_update,String value_update,MongoCollectioncollection) {    
        // 更新一条文档
        Document filter = new Document(key_filter,value_filter);
        Document update = new Document("$set", new Document(key_update,value_update));
        return collection.updateOne(filter, update);
    }
    
    public UpdateResult updateOneDocument(String key_filter,String value_filter,String key_update,int value_update,MongoCollectioncollection) {
       // 更新一条文档
       Document filter = new Document(key_filter,value_filter);
       Document update = new Document("$set", new Document(key_update,value_update));
       return collection.updateOne(filter, update);
   }
        
    public UpdateResult updateManyDocument(String key_filter,String value_filter,String key_update,int value_update,MongoCollectioncollection) {
           // 更新多条文档
           Document filter = new Document(key_filter,value_filter);
           Document update = new Document("$set", new Document(key_update,value_update));
           return collection.updateMany(filter, update);
    }
    
    public UpdateResult updateManyDocument(String key_filter,int value_filter,String key_update,int value_update,MongoCollectioncollection) {
           // 更新多条文档
           Document filter = new Document(key_filter,value_filter);
           Document update = new Document("$set", new Document(key_update,value_update));
           return collection.updateMany(filter, update);
    }    
    
    
    public DeleteResult deleteManyDocument(String key,String value,MongoCollectioncollection) {
        // 删除多条文档
           Document filter = new Document(key, value);
           return collection.deleteOne(filter);
    }
    
    public DeleteResult deleteManyDocument(String key,int value,MongoCollectioncollection) {
        // 删除多条文档
           Document filter = new Document(key, value);
           return collection.deleteMany(filter);
    }
    
    public DeleteResult deleteOneDocument(String key,String value,MongoCollectioncollection) {    
        // 删除一条文档
           Document filter = new Document(key, value);
           return collection.deleteOne(filter);
    }
    
    public DeleteResult deleteOneDocument(String key,int value,MongoCollectioncollection) {
        // 删除一条文档
           Document filter = new Document(key, value);
           return collection.deleteOne(filter);
    }
}

JUnit5 测试代码testMongoDB.java

代码语言:javascript

复制

package mongoDB;
           
import org.bson.Document; 
import static org.assertj.core.api.Assertions.assertThat;
import org.junit.jupiter.api.Test;    
           
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.jupiter.api.AfterAll;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.BeforeAll;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.DisplayName;
           
import com.mongodb.client.FindIterable;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoCursor;
import com.mongodb.client.MongoDatabase;
import com.mongodb.client.result.DeleteResult;
import com.mongodb.client.result.UpdateResult;
           
public class testMongoDB {    
       static MongoDB mdb = new MongoDB();
       static MongoCollectioncollection = null;
       static String key1 = "name";
       static String value1 = "Jone";
       static String key2 = "age";
       static int value2 = 35;
       static String[][] values = {{"Alice","25"},{"Bob","25"},{"Jerry","25"}};
           
       @BeforeAll
       @DisplayName("运行所有测试用例前连接数据库")
       public static void  startALL(){
           MongoDatabase database = mdb.connect("admin");
           collection = mdb.getCollection(database,"person");
              
       }
           
       @AfterAll
       @DisplayName("运行所有测试用例后断开数据库")    
       public static void endAll(){
              mdb.disconnect();
       }
       
       @BeforeEach
       @DisplayName("每条用例开始时执行")
       public void start(){
              mdb.insertOneDocument(key1,value1,key2,value2,collection);
              mdb.insertManyDocument(values,collection);
       }
       
       @AfterEach
       @DisplayName("每条用例结束时执行")
       public void end(){
              mdb.deleteOneDocument(key1,value1,collection);
              mdb.deleteManyDocument("age",25,collection);
       }
               
       @Test
       @DisplayName("测试显示所有的记录")
       public void testViewAllDocument() {
              boolean judge=false;
              FindIterableiterable=mdb.ViewAllDocument(collection);
              for (Document document : iterable) {
                     assertThat(document.toJson().matches("\"$oid\":^[A-Za-z0-9]+$")); 
                     assertThat(document.toJson().matches("\"name\":^[A-Za-z]+$"));
                     assertThat(document.toJson().matches("\"age\":\\d+")); 
                     judge = true;
           }
              Assertions.assertTrue(judge);
       }
       
       @Test    
       @DisplayName("测试模糊查询")
       public void testFuzzyQuery() {
              boolean judge=false;
              String key = "name";
              String value ="J";
              FindIterableiterable = mdb.fuzzyQuery(key, value,collection);
              for (Document document : iterable) {
                     assertThat(document.toJson().matches("\"$oid\":^[A-Za-z0-9]+$")); 
                     assertThat(document.toJson().matches("\"name\": \"Q"));
                     assertThat(document.toJson().matches("\"age\":\\d+")); 
                     judge = true;
           }
              Assertions.assertTrue(judge);
       }
       
       @Test    
       @DisplayName("测试setUp()函数中插入的一条数据是否成功")
       public void testInsertOneDocument() {
              judgeDataInDB(key1,value1);
       }
       
       @Test
       @DisplayName("测试setUp()函数中插入的多条数据是否成功")
       public void testInsertManyDocument() {
              for (int i = 0;i < 3 ;i++) {
                     judgeDataInDB(key1,values[i][0]);
              }
       }
       
       @Test
       @DisplayName("测试修改一条数据是否成功")
       public void testUpdateOneDocument() {
              String key_filter = "name";
              String value_filter ="Alice";    
              String key_update = "age";
              int value_update = 25;
              UpdateResult updateOne = mdb.updateOneDocument(key_filter,value_filter,key_update,value_update,collection);
              assertThat(String.valueOf(updateOne).matches("matchedCount=1, modifiedCount=1"));
       }
       
       @Test
       @DisplayName("测试修改多条数据是否成功")
       public void testUpdateManyDocument() {
              String key_filter = "age";
              int value_filter =25;
              String key_update = "age";
              int value_update = 30;
              UpdateResult updateOne = mdb.updateManyDocument(key_filter,value_filter,key_update,value_update,collection);    
              assertThat(String.valueOf(updateOne).matches("matchedCount=2, modifiedCount=2"));
       }
       
       @Test
       @DisplayName("测试删除一条数据是否成功")
       public void testDeleteOneDocument() {
              String key_filter = "name";
              String value_filter ="Alice";
              DeleteResult deleteOne = mdb.deleteOneDocument(key_filter,value_filter,collection);
              assertThat(String.valueOf(deleteOne).matches("matchedCount=1, modifiedCount=1"));
       }
       
       @Test
       @DisplayName("测试删除多条数据是否成功")
       public void testDeleteManyDocument() {    
              String key_filter = "age";
              int value_filter =25;
              DeleteResult deleteOne = mdb.deleteManyDocument(key_filter,value_filter,collection);
              assertThat(String.valueOf(deleteOne).matches("matchedCount=2, modifiedCount=2"));
       }
       
       //验证数据是否在数据库中
       public void judgeDataInDB(String key_update,String value_update) {
              MongoCursorcursor=mdb.searchDocument(key_update,String.valueOf(value_update),collection);
              while (cursor.hasNext()) {
                     Document result = cursor.next();
                  assertThat(result.toJson().matches("\""+key_update+"\":\""+String.valueOf(value_update)+"\""));
           }
       }     
}
相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。 &nbsp; 相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
目录
相关文章
|
14小时前
|
测试技术
更正以前风险调整中的一个缺陷
以前在我写的书《软件测试技术实战——设计、工具及管理》中提及一个关于风险调整的策略是完全错误的,现在更正如下
49 35
|
11天前
|
Java
Java快速入门之判断与循环
本文介绍了编程中的流程控制语句,主要包括顺序结构、判断结构(if语句和switch语句)以及循环结构(for、while和do...while)。通过这些语句可以精确控制程序的执行流程。if语句有三种格式,分别用于简单条件判断、二选一判断和多条件判断。switch语句适用于有限个离散值的选择判断,而循环结构则用于重复执行某段代码,其中for循环适合已知次数的情况,while循环适合未知次数但有明确结束条件的情况,do...while则是先执行后判断。文中还提供了多个示例和练习,帮助读者理解并掌握这些重要的编程概念。
|
14小时前
|
前端开发 JavaScript 测试技术
使用ChatGPT生成登录产品代码的测试用例和测试脚本
使用ChatGPT生成登录产品代码的测试用例和测试脚本
44 29
|
11天前
|
机器学习/深度学习 Python
北美七个站点雨量计的 2 级(L2)校准小时降水量(厘米/小时)—机载下冠层和地表下微波观测站(AirMOSS)项目
**AirMOSS: L2 小时降水量数据集 (2011-2015)** 该数据集记录了北美七个站点的2级(L2)校准小时降水量(厘米/小时),是机载下冠层和地表下微波观测站(AirMOSS)项目的一部分。每个站点安装了三个雨量计,采样始于2011年9月,并于2015年12月结束。这些数据用于研究降水对地表水分含量和地下水补给的影响,支持气候变化及生态系统研究。
63 41
|
4天前
|
机器学习/深度学习 存储 运维
深度学习在数据备份与恢复中的新视角:智能化与效率提升
深度学习在数据备份与恢复中的新视角:智能化与效率提升
42 19
|
10天前
|
SQL 数据库 Python
手动进行参数化查询时,如何确保参数的数据类型正确?
手动进行参数化查询时,如何确保参数的数据类型正确?
35 17
|
4天前
|
存储 消息中间件 druid
Druid 架构原理及核心特性详解
Druid 是一个分布式、支持实时多维OLAP分析的列式存储数据处理系统,适用于高速实时数据读取和灵活的多维数据分析。它通过Segment、Datasource等元数据概念管理数据,并依赖Zookeeper、Hadoop和Kafka等组件实现高可用性和扩展性。Druid采用列式存储、并行计算和预计算等技术优化查询性能,支持离线和实时数据分析。尽管其存储成本较高且查询语言功能有限,但在大数据实时分析领域表现出色。
46 19
|
4天前
|
存储 缓存 监控
ClickHouse 架构原理及核心特性详解
ClickHouse 是由 Yandex 开发的开源列式数据库,专为 OLAP 场景设计,支持高效的大数据分析。其核心特性包括列式存储、字段压缩、丰富的数据类型、向量化执行和分布式查询。ClickHouse 通过多种表引擎(如 MergeTree、ReplacingMergeTree、SummingMergeTree)优化了数据写入和查询性能,适用于电商数据分析、日志分析等场景。然而,它在事务处理、单条数据更新删除及内存占用方面存在不足。
88 21
|
1天前
|
Shell Linux Ruby
Python3虚拟环境venv
`venv` 是 Python 的虚拟环境工具,用于为不同项目创建独立的运行环境,避免依赖冲突。通过 `python3 -m venv` 命令创建虚拟环境,并使用 `source bin/activate` 激活。激活后,所有 Python 包将安装在该环境中,不影响系统全局环境。退出环境使用 `deactivate` 命令。每个虚拟环境拥有独立的包集合,确保项目间的隔离性。删除虚拟环境只需删除其目录即可。
50 34
|
5天前
|
缓存 NoSQL 架构师
Redis批量查询的四种技巧,应对高并发场景的利器!
在高并发场景下,巧妙地利用缓存批量查询技巧能够显著提高系统性能。 在笔者看来,熟练掌握细粒度的缓存使用是每位架构师必备的技能。因此,在本文中,我们将深入探讨 Redis 中批量查询的一些技巧,希望能够给你带来一些启发。
57 23
Redis批量查询的四种技巧,应对高并发场景的利器!