• 看十年架构师用Spring Boot 整合 MongoDB 实战解说


    一、介绍

    在前面的文章中,我们详细地介绍了 MongoDB 的配置和使用,如果你对 MongoDB 还不是很了解,也没关系,在 MongoDB 中有三个比较重要的名词:数据库、集合、文档

    • 数据库(Database):和关系型数据库一样,每个数据库中有自己的用户权限,不同的项目组可以使用不同的数据库
    • 集合(Collection): 集合指的是文档组(类似于 Mysql 中的表的概念),里面可以存储许多文档
    • 文档(Document): 文档是 MongoDB 中最基本的数据单元,由键值对组成,类似于 JSON 格式,可以存储不同字段,字段的值可以包括其他文档、数组和文档数组

    搞懂这三个名词,基本就可以上手了,今天我们以 Java 语言为例,详细地介绍 Java 客户端改如何操作 MongoDB !

    话不多说,直接开撸!

    二、Java 客户端

    2.1、MongoDB 连接

    Java 连接 MongoDB 服务器,与我们常用的连接关系型数据库方式类似!

    标准 URI 连接语法:

    mongodb://username:password@host1:port1,host2:port2,...,hostN:portN/database?options
    

    参数说明:

    • mongodb://:这是固定的格式,必须要指定
    • username:password@:可选项,如果设置,在连接数据库服务器之后,驱动都会尝试登录这个数据库
    • host1:port1:主机IP和端口号,必须指定至少一个host。如果要连接复制集,请指定多个主机地址
    • /database:如果指定了username:password@,连接时会验证并登录指定数据库。若不指定,默认打开 test 数据库
    • ?options:连接可选项,例如connectTimeoutMS=5000ms,表示连接等待时间最长 5 秒

    例如,无密码连接 MongoDB

    mongodb://127.0.0.1:27017
    

    使用用户名test,密码test登录 MongoDB 的test_db数据库

    mongodb://test:test@127.0.0.1:27017/test_db
    

    无密码连接指定三台服务器 (端口 27017, 27018, 和27019)

    mongodb://127.0.0.1:27017,127.0.0.1:27018,127.0.0.1:27019
    

    2.2、添加依赖包

    和关系型数据库操作一样,在 Java 程序中如果要使用 MongoDB,先要添加对应的 MongoDB JDBC 驱动器,然后才能继续操作!

    在选择的版本号的时候,注意需要和服务器中的安装版本匹配,具体的版本号选择可以从如下地址中获取到最新的版本:mongo-java-driver

    1. <dependency>
    2. <groupId>org.mongodb</groupId>
    3. <artifactId>mongo-java-driver</artifactId>
    4. <version>3.12.7</version>
    5. </dependency>

    2.3、连接数据库

    连接数据库的 Java 代码如下:

    1. private static MongoClient mongoClient;
    2. static {
    3. try {
    4. //连接到MongoDB服务 如果是远程连接可以替换“localhost”为服务器所在IP地址
    5. mongoClient = MongoClients.create("mongodb://test:test@127.0.0.1:27017/test_db");
    6. System.out.println("Connect to database successfully");
    7. } catch (Exception e) {
    8. System.err.println( e.getClass().getName() + ": " + e.getMessage() );
    9. }
    10. }

    上文中采用的是用户名和密码方式登录数据库,因为数据库已经开启了权限验证,因此需要通过用户名和密码才能登录。

    2.4、创建集合

    com.mongodb.client包里面都帮我们集成好了大部分常用的 api,我们可以通过MongoDatabase类中的createCollection()方法来创建集合。

    创建一个tb_role集合,代码片段如下:

    1. /**
    2. * 创建集合
    3. * @param args
    4. */
    5. public static void main(String[] args) {
    6. // 连接到数据库
    7. MongoDatabase mongoDatabase = mongoClient.getDatabase("test_db");
    8. System.out.println("Connect to database successfully");
    9. mongoDatabase.createCollection("tb_role");
    10. System.out.println("集合创建成功");
    11. }

    如果想删除集合,操作也很简单!

    1. /**
    2. * 删除集合
    3. * @param args
    4. */
    5. public static void main(String[] args) {
    6. // 连接到数据库
    7. MongoDatabase mongoDatabase = mongoClient.getDatabase("test_db");
    8. System.out.println("Connect to database successfully");
    9. mongoDatabase.getCollection("tb_role").drop();
    10. System.out.println("集合 tb_role 删除成功");
    11. }

    2.5、创建文档

    我们可以通过MongoCollection类中的insertMany()方法来插入一个文档。

    向tb_role集合中插入文档,代码片段如下:

    1. /**
    2. * 插入文档
    3. * @param args
    4. */
    5. public static void main(String[] args) {
    6. // 连接到数据库
    7. MongoDatabase mongoDatabase = mongoClient.getDatabase("test_db");
    8. System.out.println("Connect to database successfully");
    9. //获取集合
    10. MongoCollection<Document> collection = mongoDatabase.getCollection("tb_role");
    11. //向集合中插入文档
    12. Document document = new Document("name", "管理员").
    13. append("code", "manager").
    14. append("sort", 100);
    15. List<Document> documents = new ArrayList<>();
    16. documents.add(document);
    17. collection.insertMany(documents);
    18. System.out.println("文档插入成功");
    19. }

    2.6、更新文档

    我们可以通过MongoCollection类中的updateMany()方法来更新集合中的文档。

    更新tb_role集合中的指定文档信息,代码片段如下:

    1. /**
    2. * 更新文档
    3. * @param args
    4. */
    5. public static void main(String[] args) {
    6. // 连接到数据库
    7. MongoDatabase mongoDatabase = mongoClient.getDatabase("test_db");
    8. System.out.println("Connect to database successfully");
    9. //获取集合
    10. MongoCollection<Document> collection = mongoDatabase.getCollection("tb_role");
    11. //更新文档
    12. collection.updateMany(Filters.eq("code", "manager"), new Document("$set",new Document("name","经理")));
    13. //遍历所有文档
    14. FindIterable<Document> findIterable = collection.find();
    15. MongoCursor<Document> mongoCursor = findIterable.iterator();
    16. while(mongoCursor.hasNext()){
    17. System.out.println(mongoCursor.next());
    18. }
    19. }

    上文操作类似于 SQL语句中的update tb_role set name = '经理' where code = 'manager'!

    2.7、删除文档

    我们可以通过MongoCollection类中的deleteOne()或者deleteMany方法来删除集合中的文档。

    删除tb_role集合中的指定文档信息,代码片段如下:

    1. /**
    2. * 删除文档
    3. * @param args
    4. */
    5. public static void main(String[] args) {
    6. // 连接到数据库
    7. MongoDatabase mongoDatabase = mongoClient.getDatabase("test_db");
    8. System.out.println("Connect to database successfully");
    9. //获取集合
    10. MongoCollection<Document> collection = mongoDatabase.getCollection(&#
  • 相关阅读:
    网页数据采集HTTP Get,Post登录提交数据--VBS之Microsoft.XMLHTTP对象
    Go语言内置类型和函数
    (附源码)计算机毕业设计SSM敬老院信息管理系统
    Codeforces Round 855 (Div 3)(A - F)
    c语言基础知识+OS+数据结构
    Blazor OIDC 单点登录授权实例5 - 独立SSR App (net8 webapp ) 端授权
    JavaScript脚本操作CSS
    【UML用户指南】-31-对体系结构建模-制品图
    【毕业设计】 stm32单片机的远程WIFI密码锁 - 物联网 嵌入式
    firefly3399专题1-uboot2022.10的移植
  • 原文地址:https://blog.csdn.net/Java_zhujia/article/details/127746338