SpringBoot整合Mongodb实现增删查改的方法

 更新时间:2022-05-13 14:10:16   作者:佚名   我要评论(0)

目录一、什么是MongoDB二、在Window10上安装MongoDB三、配置MongoDB服务四、启动服务五、SpringBoot整合MongoDB一、什么是MongoDB
MongoDB与

一、什么是MongoDB

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

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

二、在Window10上安装MongoDB

打开MongoDB官网

下载MSI版本(安装版)

下载的时候选择Custom

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

三、配置MongoDB服务

配置环境变量

复制当前路径

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

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

四、启动服务

win+R->输入services.msc

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

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

五、SpringBoot整合MongoDB

环境准备

操作系统:Window10

IDE:IntelliJ IDEA 2018.2.4

数据库:MongoDB

1)引入依赖

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-mongodb</artifactId>
        </dependency>

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);
    }

数据库信息:

可以看到,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);
    }

更新后数据库如图所示:

测试四:删除操作

    @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增删查改内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • springboot整合mongodb?changestream的示例代码
  • springboot整合mongodb并实现crud步骤详解
  • SpringBoot整合之SpringBoot整合MongoDB的详细步骤
  • SpringBoot整合MongoDB的实现步骤
  • SpringBoot配置MyBatis-Plus实现增删查改
  • 使用springboot整合mybatis-plus实现数据库的增删查改示例

相关文章

  • SpringBoot整合Mongodb实现增删查改的方法

    SpringBoot整合Mongodb实现增删查改的方法

    目录一、什么是MongoDB二、在Window10上安装MongoDB三、配置MongoDB服务四、启动服务五、SpringBoot整合MongoDB一、什么是MongoDB MongoDB与
    2022-05-13
  • Java实现跳跃表的示例详解

    Java实现跳跃表的示例详解

    跳表全称叫做跳跃表,简称跳表,是一个随机化的数据结构,实质就是一种可以进行二分查找的有序链表。跳表在原有的有序列表上面增加多级索引,
    2022-05-13
  • go语言心跳超时的实现示例

    go语言心跳超时的实现示例

    目录一、背景二、心跳超时的实现2.1 通过select case (设计概念比较多)2.2 通过time.sleep(简单有效)三、个人的实现观感一、背景 本文描
    2022-05-13
  • 利用Java编写一个属于自己的日历

    利用Java编写一个属于自己的日历

    目录问题提出一点提示源码分享问题提出 编写程序,输入年份,打印出该年的年历(12个月的),效果如下图所示。 一点提示 使用 Java 自带的
    2022-05-13
  • centos安装ElasticSearch教程

    centos安装ElasticSearch教程

    CentOS7.9-ES7 部署下载 https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.11.2-linux-x86_64.tar.gz解压tar -zxvf elasticsearch-7.11.2-linux-x86
    2022-05-13
  • Nevercenter Silo Pro(3D多边形建模) 2022.0 beta 2 x64 破解版 附激活教程

    Nevercenter Silo Pro(3D多边形建模) 2022.0 beta 2 x64 破解版 附激活教程

    Nevercenter Silo Pro(3D多边形建模) 2022.0 beta 2 x64 破解版 附激活教程,Nevercenter Silo Pro 2022激活版是一款轻量级、闪电般快速的 3D 多边形建模器和 UV 映射器,以极其实惠的价格提供深度的工业级工具集和易于掌握的工作流程。其轻巧、专注和便携的特性使其成为十多年来的首选纯建模器
    2022-04-14
  • NevercenterSilo激活补丁 2022.0 beta 2 x64 附破解教程

    NevercenterSilo激活补丁 2022.0 beta 2 x64 附破解教程

    NevercenterSilo激活补丁 2022.0 beta 2 x64 附破解教程,怎么激活Nevercenter Silo Pro 2022?Nevercenter Silo Pro 2022激活补丁分享!今天给大家分享的是Nevercenter Silo Pro 2022的激活补丁,此款补丁可以快速完美的激活Nevercenter Silo Pro 2022最新版本,下面有详细的安装激活教程
    2022-04-14
  • SolidWorks 2022 SP0-2.0 Full Premium 中文完美破解版(附激活补丁+教程) 64位

    SolidWorks 2022 SP0-2.0 Full Premium 中文完美破解版(附激活补丁+教程) 64位

    SolidWorks 2022 SP0-2.0 Full Premium 中文完美破解版(附激活补丁+教程) 64位,SolidWorks 2022破解版是一款计算机辅助设计、工程分析和准备,用于生产任何复杂性和用途的产品,SolidWorks 2022新的增强功能,可理顺和加速整个产品开发流程,从而提高效率、提升准确性和改善协作
    2022-04-13
  • ASP.NET?Core中的Caching组件简介

    ASP.NET?Core中的Caching组件简介

    在.NET Core中提供了Caching的组件。目前Caching组件提供了三种存储方式: MemoryRedisSQLSever 1.Memeor Caching 新建一个ASP.NET Core Web
    2022-04-13
  • C语言指针超详细讲解下篇

    C语言指针超详细讲解下篇

    目录前言指针运算指针&plusmn;整数4.1 指针&plusmn;整数4.2 指针-指针4.3 指针的关系运算5、指针和数组6、二级指针7、指针数组7.1 举例 17.2
    2022-04-13

最新评论