SpringBoot怎么整合Mongodb实现增删查改

一、什么是MongoDB

mongodb与我们之前熟知的关系型数据库(mysql、oracle)不同,mongodb是一个文档数据库,它具有所需的可伸缩性和灵活性,以及所需的查询和索引。

MongoDB将数据存储在灵活的、类似JSON的文档中,这意味着文档的字段可能因文档而异,数据结构也会随着时间的推移而改变。文档模型映射到应用程序代码中的对象,使数据易于处理。MongoDB是一个以分布式数据库为核心的数据库,因此高可用性、横向扩展和地理分布是内置的,并且易于使用。况且,MongoDB是免费的,开源的。

二、在Window10上安装MongoDB

打开MongoDB官网

SpringBoot怎么整合Mongodb实现增删查改

下载MSI版本(安装版)

SpringBoot怎么整合Mongodb实现增删查改

下载的时候选择Custom

SpringBoot怎么整合Mongodb实现增删查改

安装的时候,注意不要勾上安装可视化插件,否则安装会非常慢(除非你网速够快)

SpringBoot怎么整合Mongodb实现增删查改

三、配置MongoDB服务

配置环境变量

复制当前路径

SpringBoot怎么整合Mongodb实现增删查改

我的电脑->右键->高级系统设置->环境变量->系统变量

在系统变量找到Path,编辑,将上面复制的路径增加进去

SpringBoot怎么整合Mongodb实现增删查改

四、启动服务

win+R->输入services.msc

SpringBoot怎么整合Mongodb实现增删查改

SpringBoot怎么整合Mongodb实现增删查改

服务启动后,在浏览器输入 127.0.0.1:2701

SpringBoot怎么整合Mongodb实现增删查改

出现这行英语则代表服务启动成功。

五、SpringBoot整合MongoDB

环境准备

操作系统:Window10

IDE:IntelliJ IDEA 2018.2.4

数据库:MongoDB

1)引入依赖

                    org.springframework.boot            spring-boot-starter-data-mongodb        

登录后复制

2)在application.yml添加如下配置

spring:  data:    mongodb:      uri: mongodb://localhost/test_mongodb

登录后复制

完整的配置信息如下:

spring:  data:    mongodb:      authentication-database: # Authentication database name.      database: # Database name.      field-naming-strategy: # Fully qualified name of the FieldNamingStrategy to use.      grid-fs-database: # GridFS database name.      host: # Mongo server host. Cannot be set with URI.      password: # Login password of the mongo server. Cannot be set with URI.      port: # Mongo server port. Cannot be set with URI.      repositories:        type: # Type of Mongo repositories to enable.      uri: # Mongo database URI. Cannot be set with host, port and credentials.      username: # Login user of the mongo server. Cannot be set with URI.

登录后复制

3)新增实体类UserEntity

public class UserEntity {    @Id    private String uid;    private String username;    private String password;    public String getUid() {        return uid;    }    public void setUid(String uid) {        this.uid = uid;    }    public String getUsername() {        return username;    }    public void setUsername(String username) {        this.username = username;    }    public String getPassword() {        return password;    }    public void setPassword(String password) {        this.password = password;    }    @Override    public String toString() {        return "UserEntity{" +                "uid='" + uid + '\'' +                ", username='" + username + '\'' +                ", password='" + password + '\'' +                '}';    }}

登录后复制

4)新建测试。这里我用navicat作为MongoDB的可视化工具进行查看。

测试一:插入操作

    @Autowired    private MongoTemplate mongoTemplate;    @Test    public void saveUser(){        UserEntity userEntity1 = new UserEntity();        UserEntity userEntity2 = new UserEntity();        UserEntity userEntity3 = new UserEntity();        userEntity1.setUid("111");        userEntity1.setUsername("用户1");        userEntity1.setPassword("密码1");        userEntity2.setUid("222");        userEntity2.setUsername("用户2");        userEntity2.setPassword("密码2");        userEntity3.setUid("333");        userEntity3.setUsername("用户3");        userEntity3.setPassword("密码3");        mongoTemplate.save(userEntity1);        mongoTemplate.save(userEntity2);        mongoTemplate.save(userEntity3);    }

登录后复制

数据库信息:

SpringBoot怎么整合Mongodb实现增删查改

可以看到,MongoDB自动创建了数据库以及通过实体类生成了集合(也就是我们经常说的数据表),而且我们已经通过MongoTemplate往数据库的userEntity集合插入了几条文档(也就是插入了几条记录)。而 _id 为主键,_class 则为实体类包名+类名

测试二:查询操作

    @Autowired    private MongoTemplate mongoTemplate;@Test    public void findUserByUserName(){        String username = "用户1";        Query query=new Query(Criteria.where("username").is(username));        UserEntity user =  mongoTemplate.findOne(query , UserEntity.class);        System.out.println(user);    }

登录后复制

输出结果:

UserEntity{uid=’111′, username=’用户1′, password=’密码1′}测试三:更新操作

  @Autowired    private MongoTemplate mongoTemplate;    @Test    public void updateUser(){        UserEntity userEntity = new UserEntity();        userEntity.setUid("111");        userEntity.setUsername("更新后的用户名");        userEntity.setPassword("更新后的密码");        Query query = new Query(Criteria.where("_id").is(userEntity.getUid()));        Update update = Update.update("username",userEntity.getUsername()).set("password",userEntity.getPassword());        //更新返回结果集的第一条        mongoTemplate.updateFirst(query,update,UserEntity.class);        //更新返回结果集的所有        //mongoTemplate.updateMulti(query,update,UserEntity.class);    }

登录后复制

更新后数据库如图所示:

SpringBoot怎么整合Mongodb实现增删查改

测试四:删除操作

    @Autowired    private MongoTemplate mongoTemplate; @Test    public  void DeleteByUserId(){        String id = "222";        Query query=new Query(Criteria.where("_id").is(id));        mongoTemplate.remove(query,UserEntity.class);    }

登录后复制

删除后数据库如图所示:

SpringBoot怎么整合Mongodb实现增删查改

以上就是SpringBoot怎么整合Mongodb实现增删查改的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3156205.html

(0)
上一篇 2025年3月30日 10:07:58
下一篇 2025年3月30日 10:08:10

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Debian MongoDB如何进行数据加密

    在Debian系统上为MongoDB数据库加密,需要遵循以下步骤: 第一步:安装MongoDB 首先,确保您的Debian系统已安装MongoDB。 如果没有,请参考MongoDB官方文档进行安装:https://www.php.cn/li…

    2025年4月5日
    400
  • 开源替代品的演进和未来趋势有哪些?

    开源替代品的未来趋势包括:人工智能集成、云原生部署和可持续性实践。这些替代品演变自 80 年代,为广泛的应用提供低成本、灵活和受社区支持的解决方案。一个实战案例是 kubernetes,它是一个容器编排平台,在云计算中被广泛采用,简化了分布…

    2025年4月2日
    100
  • 哪些开源替代品具有独特的特性和优势?

    postgresql、mongodb、redis 和 mariadb 等开源数据库引擎提供独特的特性和优势:postgresql:可扩展性、安全性、jsonb 支持mongodb:文档结构、分布式架构、云服务redis:内存数据库、键值存储…

    2025年4月2日
    100
  • 最佳的开源替代品在哪些行业和用例中使用?

    开源替代品广泛应用于各个行业,提供与专有软件相当的功能,成本和限制更低。这些应用包括云计算、数据库、办公套件、操作系统和开发工具。例如,金融行业使用开源替代品创建了风险管理系统,降低了成本并提高了灵活性。随着开源软件的成熟,其采用范围预计将…

    2025年4月2日
    300
  • 如何在Workerman中使用MongoDB进行数据存储

    如何在Workerman中使用MongoDB进行数据存储 Workerman是一种基于PHP的高性能网络编程框架,它提供了丰富的功能和灵活的扩展性,使开发者能够更简便地构建高性能的网络应用。而MongoDB是一种非关系型数据库,以其高性能、…

    2025年4月2日
    100
  • laravel支持几种数据库

    Laravel 支持多种数据库连接,包括:MySQL、PostgreSQL、SQLite、SQL Server、MariaDB、MongoDB 和 Redis。要连接到数据库,您需要在 .env 文件中设置配置并使用 DB 外观进行连接。 …

    2025年4月2日
    100
  • MongoDB集群在CentOS上如何搭建

    在centos系统上搭建mongodb集群,需要完成mongodb安装、实例配置、副本集设置以及分片等步骤。以下步骤将详细指导您完成这一过程: 一、准备工作 确保CentOS系统已更新,并安装必要的工具: sudo yum update -…

    编程技术 2025年4月2日
    100
  • CentOS MongoDB如何进行故障排查

    centos系统下mongodb故障诊断指南 本文提供一个系统化的步骤,帮助您在CentOS系统上有效排查MongoDB数据库问题。 请按照以下步骤逐步进行诊断,并仔细检查每个步骤的结果。 一、检查系统日志 首先,检查系统日志中是否存在与M…

    编程技术 2025年4月2日
    100
  • Debian syslog性能如何

    Debian系统中的Syslog性能表现如何?总的来说,它稳定高效,非常适合需要集中管理和分析日志的系统。Debian通常使用rsyslog守护进程来管理Syslog,该进程能够高效地收集和处理日志。以下是Debian Syslog性能的详…

    2025年4月2日
    100
  • 如何优化CentOS MongoDB的索引

    提升centos环境下mongodb数据库性能的关键在于索引优化。本文将指导您逐步优化mongodb索引,从而提升查询速度和整体数据库效率。 1. 诊断查询模式 利用explain()方法:对频繁使用的查询语句运用explain()方法,分…

    编程技术 2025年4月2日
    200

发表回复

登录后才能评论