SpringBoot整合MongoDB


本節使用SpringBoot 2.1.9.RELEASE,示例源碼https://github.com/laolunsi/spring-boot-examples


SpringBoot可以非常方便地引入和操作MongoDB。本節分兩部分,記錄個人學習SpringBoot使用MongoDB數據庫的一些知識。

第一部分是一個簡單的springboot連接mongo的demo,測試查詢功能。

第二部分是基於mongo實現的增刪改查數據示例。


一、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,插入幾條數據,比如:

file
注:這里用的可視化工具是robo 3t:https://robomongo.org/

我們這里先默認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表里的數據全部刪掉。

file

注:這里用的可視化工具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模擬一下請求:

新增用戶

file

查看Mongodb:

file

更改數據,新增多個用戶:

file

列表查詢

file

更改user

file

file

刪除user:
file

file


好,到此為止,我們已經在SpringBoot項目中引入了MongoDB,並實現了基本的增刪改查操作,這將是我們使用MongoDB開發更加復雜的業務的基礎!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM