SpringBoot整合MongoDB的示例

本节使用SpringBoot 2.1.9.RELEASE,示例源码在https://github.com/laolunsi/spring-boot-examples/tree/master/06-spring-boot-mongo-demo

SpringBoot可以非常方便地引入和操作MongoDB。本节分两部分,记录个人学习SpringBoot使用MongoDB数据库的一些知识。

第一部分是一个简单的springboot连接mongo的demo,测试查询功能。

第二部分是基于mongo实现的增删改查数据示例。

本节使用SpringBoot 2.1.9.RELEASE

一、A simple demo

首先来演示SpringBoot项目引入MongoDB,以及一个简单的findAll操作。

maven依赖:

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

环境配置:

application.yml文件中写入如下配置,test表示MongoDB中的test表

spring:
 data:
  mongodb:
   uri: "mongodb://localhost:27017/test"

以一个bean类为例:

package com.example;

public class User {

  private String id;
  private String name;
  private Integer age;
  private Integer grade;

  // ... ignore getter and setter

  // override its toString method
  @Override
  public String toString() {
    return "User{" +
        "id='" + id + '\'' +
        ", name='" + name + '\'' +
        ", age=" + age +
        ", grade=" + grade +
        '}';
  }
}

在MongoDB数据库中新建一个collection(也就是表),名字叫user,插入几条数据,比如:

注:这里用的可视化工具是robo 3t:https://www.jb51.net/database/567493.html

我们这里先默认JavaBean的字段与user表的字段名保持一致。

下面我们编写测试类:

@SpringBootTest
@RunWith(SpringRunner.class)
public class MongoTest {

  @Autowired
  private MongoTemplate mongoTemplate;

  @Test
  public void test1() {
    List<User> userList = mongoTemplate.findAll(User.class);
    if (userList != null && userList.size() > 0) {
      userList.forEach(user -> {
        System.out.println(user.toString());
      });
    }
  }

}

运行测试类,输出如下:

User{id='5d243534514701183f5fcab8', name='zf0', age=12, grade=1}
User{id='5d243534514701183f5fcab9', name='zf1', age=13, grade=2}
User{id='5d243534514701183f5fcaba', name='zf2', age=14, grade=3}
User{id='5d243534514701183f5fcabb', name='zf3', age=15, grade=4}
User{id='5d243534514701183f5fcabc', name='zf4', age=16, grade=5}

二、基于SpringBoot的MongoDB增删改查操作

下面来实现一个基于SpringBoot的对MongoDB增删改查操作的简单示例,依然使用上面的环境:

maven:

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

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-test</artifactId>
  <scope>test</scope>
</dependency>

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

<dependency>
  <groupId>com.alibaba</groupId>
  <artifactId>fastjson</artifactId>
  <version>1.2.60</version>
</dependency>

yml:

server:
 port: 8866

spring:
 data:
  mongodb:
   uri: "mongodb://localhost:27017/test"

User类:

这里我们清楚一下之前的数据,把mongo里的user表里的数据全部删掉。

注:这里用的可视化工具admin-mongo:https://github.com/mrvautin/adminMongo

新建一个不同的user类:

@Document("user")
public class User {

  @Id
  private String id;

  @Field("name")
  private String name;

  @Field("password")
  private String password;

  @Field("address")
  private String address;

  @Field("create_time")
  private Date createTime;

  @Field("last_update_time")
  private Date lastUpdateTime;

  // ... ignore getter and setter methods

  @Override
  public String toString() {
    return JSONObject.toJSONString(this);
  }
}

此处定义一个JsonResult类,用于封装接口返回数据:

import com.alibaba.fastjson.JSONObject;

import java.util.HashMap;
import java.util.Map;

public class JsonResult {

  /**
   * 未登录
   */
  public static final int NO_LOGIN = 400;

  /**
   * 登录失败
   */
  public static final int LOGIN_FAILED = 401;

  /**
   * TOKEN过期
   */
  public static final int TOKEN_EXPIRED = 402;

  /**
   * 无权限
   */
  public static final int NO_PERMISSION = 403;

  private Boolean success;
  private Integer code;
  private String msg;
  private Object data;

  public JsonResult(Boolean success) {
    this.success = success;
  }

  public JsonResult(Boolean success, String msg) {
    this.success = success;
    this.msg = msg;
  }

  public JsonResult(Integer code, Boolean success, String msg) {
    this.code = code;
    this.success = success;
    this.msg = msg;
  }

  public JsonResult(Boolean success, Object data) {
    this.success = success;
    this.data = data;
  }

  public JsonResult(Boolean success, Integer code, String msg, Object data) {
    this.success = success;
    this.code = code;
    this.msg = msg;
    this.data = data;
  }

  // ... ignore getter and setter methods

  public void put(String key, Object value) {
    if (data == null) {
      data = new HashMap<>();
    }
    ((Map) data).put(key, value);
  }

  public void putAll(Map<String, Object> map) {
    if (data == null) {
      data = new HashMap<>();
    }
    ((Map) data).putAll(map);
  }

  @Override
  public String toString() {
    return JSONObject.toJSONString(this);
  }
}

下面编写测试接口类,实现用户的新增、删除、更新、查询功能

UserController类:

@RestController
@RequestMapping(value = "user")
public class UserController {

  @Autowired
  private MongoTemplate mongoTemplate;

  @GetMapping(value = "")
  public JsonResult list() {
    List<User> userList = mongoTemplate.findAll(User.class, "user");
    return new JsonResult(true, userList);
  }

  @PostMapping(value = "")
  public JsonResult add(User user) {
    String msg = verifySaveForm(user);
    if (!StringUtils.isEmpty(msg)) {
      return new JsonResult(false, msg);
    }

    if (user.getId() == null) {
      user.setCreateTime(new Date());
      user.setLastUpdateTime(new Date());
      User newUser = mongoTemplate.insert(user, "user");
      return new JsonResult(true, newUser);
    } else {
      Query query = new Query();
      query.addCriteria(Criteria.where("_id").is(user.getId()));

      Update update = new Update();
      update.set("name", user.getName());
      update.set("password", user.getPassword());
      update.set("address", user.getAddress());
      update.set("last_update_time", new Date());

      UpdateResult updateResult = mongoTemplate.updateFirst(query, update, "user");
      return new JsonResult(true, updateResult);
    }
  }

  @DeleteMapping(value = "{id}")
  public JsonResult delete(@PathVariable String id) {
    Query query = new Query();
    query.addCriteria(Criteria.where("_id").is(id));
    DeleteResult deleteResult = mongoTemplate.remove(query, User.class, "user");
    return new JsonResult(true, deleteResult);
  }

  // private methods

  private String verifySaveForm(User user) {
    if (user == null || StringUtils.isEmpty(user.getName())) {
      return "用户名不能为空";
    } else if (user.getPassword() == null) {
      return "密码不能为空";
    }

    return null;
  }
}

下面用postman模拟一下请求:

新增用户:

查看Mongodb:

更改数据,新增多个用户:

列表查询:

更改user:

删除user:

以上就是SpringBoot整合MongoDB的示例的详细内容,更多关于SpringBoot整合MongoDB的资料请关注我们其它相关文章!

(0)

相关推荐

  • 详解springboot整合mongodb

    这篇文章主要介绍springboot如何整合MongoDB. 准备工作 安装 MongoDB jdk 1.8 maven 3.0 idea 环境依赖 在pom文件引入spring-boot-starter-data-mongodb依赖: <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifa

  • SpringBoot中整合knife4j接口文档的实践

    在项目开发中,web项目的前后端分离开发,APP开发,需要由前后端工程师共同定义接口,编写接口文档,之后大家都根据这个接口文档进行开发,到项目结束前都要一直维护 接口文档使得项目开发过程中前后端工程师有一个统一的文件进行沟通交流开发,项目维护中或者项目人员更迭,方便后期人员查看.维护 一.界面先赏 1.首页 2.接口文档 3.调试 二.整合 knife4j 1.引入 maven 依赖 <!-- knife4j接口文档 start --> <dependency> <group

  • SpringBoot 如何整合 ES 实现 CRUD 操作

    本文介绍 Spring Boot 项目中整合 ElasticSearch 并实现 CRUD 操作,包括分页.滚动等功能. 之前在公司使用 ES,一直用的是前辈封装好的包,最近希望能够从原生的 Spring Boot/ES 语法角度来学习 ES 的相关技术.希望对大家有所帮助. 本文为 spring-boot-examples 系列文章节选,示例代码已上传至 https://github.com/laolunsi/spring-boot-examples 安装 ES 与可视化工具 前往 ES 官方

  • SpringBoot中整合Shiro实现权限管理的示例代码

    之前在 SSM 项目中使用过 shiro,发现 shiro 的权限管理做的真不错,但是在 SSM 项目中的配置太繁杂了,于是这次在 SpringBoot 中使用了 shiro,下面一起看看吧 一.简介 Apache Shiro是一个强大且易用的Java安全框架,执行身份验证.授权.密码和会话管理.使用Shiro的易于理解的API,您可以快速.轻松地获得任何应用程序,从最小的移动应用程序到最大的网络和企业应用程序. 三个核心组件: 1.Subject 即"当前操作用户".但是,在 Shi

  • SpringBoot应用整合ELK实现日志收集的示例代码

    ELK即Elasticsearch.Logstash.Kibana,组合起来可以搭建线上日志系统,本文主要讲解使用ELK来收集SpringBoot应用产生的日志. ELK中各个服务的作用 Elasticsearch:用于存储收集到的日志信息: Logstash:用于收集日志,SpringBoot应用整合了Logstash以后会把日志发送给Logstash,Logstash再把日志转发给Elasticsearch: Kibana:通过Web端的可视化界面来查看日志. 使用Docker Compos

  • SpringBoot整合Redis的示例

    redis是最常用的缓存数据库,常用于存储用户登录token.临时数据.定时相关数据等. redis是单线程的,所以redis的操作是原子性的,这样可以保证不会出现并发问题. redis基于内存,速度非常快,据测试,redis读的速度是110000次/s,写的速度是81000次/s 本节介绍SpringBoot引入redis,以及使用RedisTemplate来操作redis数据. 采用SpringBoot 2.1.9.RELEASE,对应示例代码在:https://github.com/lao

  • springboot整合dubbo设置全局唯一ID进行日志追踪的示例代码

    1.新建项目 利用idea创建一个父项目,三个子项目,其中一个项目为生产者,一个项目为消费者,一个为接口等公共服务项目,生产者和消费者需要有web依赖,可以作为tomcat容器启动. 2.项目依赖 <dependencies> <dependency> <groupId>org.apache.dubbo</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <v

  • Springboot整合MongoDB进行CRUD操作的两种方式(实例代码详解)

    1 简介 Springboot是最简单的使用Spring的方式,而MongoDB是最流行的NoSQL数据库.两者在分布式.微服务架构中使用率极高,本文将用实例介绍如何在Springboot中整合MongoDB的两种方法:MongoRepository和MongoTemplate. 代码结构如下: 2 项目准备 2.1 启动MongoDB实例 为了方便,使用Docker来启动MongoDB,详细指导文档请参考:基于Docker的MongoDB实现授权访问的方法,这里不再赘述. 2.2 引入相关依赖

  • Springboot整合MongoDB的Docker开发教程全解

    1 前言 Docker是容器开发的事实标准,而Springboot是Java微服务常用框架,二者必然是会走到一起的.本文将讲解如何开发Springboot项目,把它做成Docker镜像,并运行起来. 2 把Springboot打包成Docker镜像 Springboot的Web开发非常简单,本次使用之前讲解过的Springboot整合MongoDB的项目,请参考 实例讲解Springboot整合MongoDB进行CRUD操作的两种方式,文章中有源码:MongoDB的安装请参考:用Docker安装

  • 2020最新IDEA SpringBoot整合Dubbo的实现(zookeeper版)

    首先,要在电脑上安装配置好zookeeper哦~ 这是我云服务器上的zookeeper状态 接下来,开始整合 1. 准备一个dubbo-api的SpringBoot项目 用来存储Entity类和Server接口的项目,配置文件无须改动. entity – User // Lombok注解 相当于Setter Getter toString() @Data public class User implements Serializable { // 序列化很重要!!! private static

  • springboot整合Mybatis-plus的实现

    1.添加pom引用 maven的引用很简单,官方已经给出starter,不需要我们考虑它的依赖关系了,此处使用的是2.3版本. <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>2.3</version> </dependency> 2.配置 serve

随机推荐