SpringBoot 整合 MongoDB 实现数据的增删改查功能

1、介绍说明

在 MongoDB 中有三个比较重要的名词:数据库、集合、文档

数据库(Database):和关系型数据库一样,每个数据库中有自己的用户权限,不同的项目组可以使用不同的数据库
集合(Collection): 集合指的是文档组(类似于 Mysql 中的表的概念),里面可以存储许多文档
文档(Document): 文档是 MongoDB 中最基本的数据单元,由键值对组成,类似于 JSON 格式,可以存储不同字段,字段的值可以包括其他文档、数组和文档数组
搞懂这三个名词,基本就可以上手了,今天我们以 SpringBoot 整合 MongoDB 为例,实现数据的增删改查。

2、代码实践

2.1、创建 SpringBoot 工程,添加 MongoDB 依赖包

<!-- 引入springboot -->
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.1.0.RELEASE</version>
</parent>

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

2.2、添加配置文件

在application.properties文件中添加mongodb相关配置!

#配置数据库连接地址

spring.data.mongodb.uri=mongodb://userName:[email protected]:27017/dbName

相关参数说明:

userName:表示用户名,根据实际情况填写即可
password:表示用户密码,根据实际情况填写即可
dbName:表示数据库,可以自定义,初始化数据的时候,会自动创建

2.3、创建实体类

创建一个实体类Stuinfo,其中注解@Document(collection=“stuInfo”)表示当前实体类对应的集合名称是stuInfo,类似于关系型数据库中的表名称。

注解@Id表示当前字段,在集合结构中属于主键类型。

/**
 * 使用@Document注解指定集合名称
 */
@Document(collection="stuInfo")
public class StuInfo implements Serializable {
    private static final long serialVersionUID = 99999999999999L;

    /**
     * 使用@Id注解指定MongoDB中的 _id 主键
     */
    @Id
    private Long id;

    private String userName;

    private String passWord;

    private Integer age;

    private Date createTime;

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

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

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public Date getCreateTime() {
        return createTime;
    }

    public void setCreateTime(Date createTime) {
        this.createTime = createTime;
    }

    @Override
    public String toString() {
        return "StuInfo{" +
                "id=" + id +
                ", userName='" + userName + '\'' +
                ", passWord='" + passWord + '\'' +
                ", age=" + age +
                ", createTime=" + createTime +
                '}';
    }
}

2.4、操作 MongoDB

Springboot 操作 MongoDB 有两种方式。

第一种方式是采用 Springboot 官方推荐的 JPA 方式,这种操作方式,使用简单但是灵活性比较差。

第二种方式是采用 Spring Data MongoDB 基于 MongoDB 官方 Java API 封装的 MongoTemplate 操作类对 MongoDB 进行操作,这种方式非常灵活,能满足绝大部分需求。

本文将采用第二种方式进行介绍

2.5、插入文档

MongoTemplate提供了insert()方法,用于插入文档,示例代码如下:

用于插入文档

没指定集合名称时,会取@Document注解中的集合名称

@Autowired
private MongoTemplate mongoTemplate;

@Test
public void mongoTest(){
   try {
      StuInfo stuInfo =new StuInfo();
      stuInfo.setId(2l);
      stuInfo.setUserName("test");
      stuInfo.setPassWord("123456");
      stuInfo.setCreateTime(new Date());
      mongoTemplate.insert(stuInfo);

      System.out.println("插入成功");
   }catch (Exception ex){
      ex.printStackTrace();
   }
}

我们可以用MongoDB Compass 工具进行查看

自定义集合名称,插入文档

指定集合名称即可

mongoTemplate.insert(stuInfo,”stuInfo”);

自定义集合,批量插入文档

如果采用批量插入文档,必须指定集合名称

List<StuInfo> list =new ArrayList<>();
StuInfo stuInfo =new StuInfo();
stuInfo.setId(3l);
stuInfo.setUserName("test3");
stuInfo.setPassWord("123456");
stuInfo.setCreateTime(new Date());
StuInfo stuInfo1 =new StuInfo();
stuInfo1.setId(4l);
stuInfo1.setUserName("test4");
stuInfo1.setPassWord("123456");
stuInfo1.setCreateTime(new Date());
list.add(stuInfo);
list.add(stuInfo1);
mongoTemplate.insert(list,"stuInfo");
System.out.println("批量插入成功");

2.6、存储文档

MongoTemplate提供了save()方法,用于存储文档。

在存储文档的时候会通过主键 ID 进行判断,如果存在就更新,否则就插入,示例代码如下:

存储文档,如果没有插入,否则通过主键ID更新

StuInfo stuInfo =new StuInfo();
stuInfo.setId(2l);
stuInfo.setUserName("修改后的名称");
stuInfo.setPassWord("123123");
stuInfo.setCreateTime(new Date());
mongoTemplate.save(stuInfo);
System.out.println("修改成功");

自定义集合,存储文档

StuInfo stuInfo =new StuInfo();
stuInfo.setId(2l);
stuInfo.setUserName("修改后的名称");
stuInfo.setPassWord("123123");
stuInfo.setCreateTime(new Date());
mongoTemplate.save(stuInfo,"stuInfo");
System.out.println("修改成功");

2.7、更新文档

MongoTemplate提供了updateFirst()和updateMulti()方法,用于更新文档,示例代码如下:

更新文档,匹配查询到的文档数据中的第一条数据

StuInfo stuInfo =new StuInfo();
stuInfo.setId(2l);
stuInfo.setUserName("修改Name");
stuInfo.setPassWord("222222");
stuInfo.setCreateTime(new Date());
//更新条件
Query query= new Query(Criteria.where("id").is(stuInfo.getId()));

//更新值
Update update= new Update().set("userName", stuInfo.getUserName()).set("passWord", stuInfo.getPassWord());
//更新查询满足条件的文档数据(第一条)
UpdateResult result =mongoTemplate.updateFirst(query,update, StuInfo.class);
if(result!=null){
   System.out.println("更新条数:" + result.getMatchedCount());
}

更新文档,匹配查询到的文档数据中的所有数据

StuInfo stuInfo =new StuInfo();
stuInfo.setId(2l);
stuInfo.setUserName("修改Name");
stuInfo.setPassWord("222222");
stuInfo.setCreateTime(new Date());
//更新条件
Query query= new Query(Criteria.where("id").is(stuInfo.getId()));

//更新值
Update update= new Update().set("userName", stuInfo.getUserName()).set("passWord", stuInfo.getPassWord());
//更新查询满足条件的文档数据(第一条)
UpdateResult result =mongoTemplate.updateMulti(query,update, StuInfo.class);
if(result!=null){
   System.out.println("更新条数:" + result.getMatchedCount());
}

2.8、删除操作

MongoTemplate提供了remove()、用于删除文档,

删除符合条件的所有文档,并返回删除的文档,这里我就不一一贴代码了,大家可以查一下帮助文档或者搜索引擎

2.9、查询文档

MongoTemplate提供了文档查询方法,日常开发中用的findById()方法,示例代码如下:

long id = 1l;
StuInfo result = mongoTemplate.findById(id, StuInfo.class);
System.out.println("查询结果:" + result.toString());

查询集合中的全部文档数据

long id = 1l;
List<StuInfo> list = mongoTemplate.findAll(StuInfo.class);
System.out.println("查询总行:" + list.size());

查询的还有很多方法,大家需要时可以查询帮助文档

3.0、索引管理

索引在所有的数据库中,暂居的位置非常重要,例如当你检索一张上百万的数据表的时候,如果没走索引,查询效率会极其缓慢,对于 MongoDB 来说,同样如此。

示例如下:

创建升序索引

// 设置字段名称
String field = "userName";
// 创建索引
mongoTemplate.getCollection("stuInfo").createIndex(Indexes.ascending(field));

移除索引

// 设置字段名称
String field = "userName";
// 创建索引
mongoTemplate.getCollection("stuInfo").dropIndex(Indexes.ascending(field));

查询集合中所有的索引

我们还可以通过在实体类上加注解方式来创建索引 @Indexed

3.1、引入 MongoDB 中的事务

单节点 mongodb 不支持事务,需要搭建 MongoDB 复制集。

3、小结

在实际的业务场景中,可能还需要用到聚合函数等高级查询,大家如果有这种需求,可以访问如下地址获取更加详细的api

spring官方文档 https://docs.spring.io/spring-data/data-mongo/docs/1.10.12.RELEASE/api/  介绍

MongoDB 官方文档查询 api https://www.mongodb.com/docs/drivers/java/ 介绍

本文主要围绕 SpringBoot 整合 MongoDB 实现数据的增删改查操作进行基本介绍,如果有描述不对的,还望网友留言指出!我会第一时间修改相关内容。假如我的这篇内容对你有任何帮助的话,麻烦给我点一个赞。你的点赞就是我前进的动力。

猜你喜欢

转载自blog.csdn.net/Angel_asp/article/details/131004832