Spring Boot 整合 MongoDB的示例
本節(jié)使用SpringBoot 2.1.9.RELEASE,示例源碼在https://github.com/laolunsi/spring-boot-examples/tree/master/06-spring-boot-mongo-demo
SpringBoot可以非常方便地引入和操作MongoDB。本節(jié)分兩部分,記錄個(gè)人學(xué)習(xí)SpringBoot使用MongoDB數(shù)據(jù)庫的一些知識(shí)。
第一部分是一個(gè)簡(jiǎn)單的springboot連接mongo的demo,測(cè)試查詢功能。
第二部分是基于mongo實(shí)現(xiàn)的增刪改查數(shù)據(jù)示例。
本節(jié)使用SpringBoot 2.1.9.RELEASE
一、A simple demo
首先來演示SpringBoot項(xiàng)目引入MongoDB,以及一個(gè)簡(jiǎn)單的findAll操作。
maven依賴:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency>
環(huán)境配置:
application.yml文件中寫入如下配置,test表示MongoDB中的test表
spring: data: mongodb: uri: "mongodb://localhost:27017/test"
以一個(gè)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數(shù)據(jù)庫中新建一個(gè)collection(也就是表),名字叫user,插入幾條數(shù)據(jù),比如:

注:這里用的可視化工具是robo 3t:http://www.dbjr.com.cn/database/567493.html
我們這里先默認(rèn)JavaBean的字段與user表的字段名保持一致。
下面我們編寫測(cè)試類:
@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());
});
}
}
}
運(yùn)行測(cè)試類,輸出如下:
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增刪改查操作
下面來實(shí)現(xiàn)一個(gè)基于SpringBoot的對(duì)MongoDB增刪改查操作的簡(jiǎn)單示例,依然使用上面的環(huán)境:
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類:
這里我們清楚一下之前的數(shù)據(jù),把mongo里的user表里的數(shù)據(jù)全部刪掉。

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

新建一個(gè)不同的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);
}
}
此處定義一個(gè)JsonResult類,用于封裝接口返回?cái)?shù)據(jù):
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;
/**
* 無權(quán)限
*/
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);
}
}
下面編寫測(cè)試接口類,實(shí)現(xiàn)用戶的新增、刪除、更新、查詢功能
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模擬一下請(qǐng)求:
新增用戶:

查看Mongodb:

更改數(shù)據(jù),新增多個(gè)用戶:

列表查詢:

更改user:


刪除user:


好,到此為止,我們已經(jīng)在SpringBoot項(xiàng)目中引入了MongoDB,并實(shí)現(xiàn)了基本的增刪改查操作,這將是我們使用MongoDB開發(fā)更加復(fù)雜的業(yè)務(wù)的基礎(chǔ)!
以上就是Spring Boot 整合 MongoDB的示例的詳細(xì)內(nèi)容,更多關(guān)于Spring Boot 整合 MongoDB的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
IDEA安裝阿里巴巴編碼規(guī)范插件的兩種方式詳解(在線安裝和離線安裝)
這篇文章主要介紹了IDEA安裝阿里巴巴編碼規(guī)范插件的兩種方式詳解(在線安裝和離線安裝),本文通過截圖給大家展示的非常詳細(xì),需要的朋友可以參考下2021-09-09
Java 實(shí)戰(zhàn)項(xiàng)目錘煉之在線購書商城系統(tǒng)的實(shí)現(xiàn)流程
讀萬卷書不如行萬里路,只學(xué)書上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實(shí)戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+jsp+mysql+servlet+ajax實(shí)現(xiàn)一個(gè)在線購書商城系統(tǒng),大家可以在過程中查缺補(bǔ)漏,提升水平2021-11-11
你必須得會(huì)的SpringBoot全局統(tǒng)一處理異常詳解
程序在運(yùn)行的過程中,不可避免會(huì)產(chǎn)生各種各樣的錯(cuò)誤,這個(gè)時(shí)候就需要進(jìn)行異常處理,本文主要為大家介紹了SpringBoot實(shí)現(xiàn)全局統(tǒng)一處理異常的方法,需要的可以參考一下2023-06-06
Java方法調(diào)用解析靜態(tài)分派動(dòng)態(tài)分派執(zhí)行過程
這篇文章主要為大家介紹了Java方法調(diào)用解析靜態(tài)分派動(dòng)態(tài)分派執(zhí)行過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06
一種新的日期處理方式之JavaScript Temporal API
JavaScript Temporal API是一種為Web開發(fā)人員提供了一種新的處理日期和時(shí)間數(shù)據(jù)類型的方式。它的目的是使操作日期和時(shí)間更加簡(jiǎn)單和可靠,而且不用擔(dān)心歷史時(shí)區(qū)問題或全球化協(xié)調(diào)時(shí)間(UTC)之類的問題,感興趣的同學(xué)可以參考閱讀2023-05-05
Java持久層框架MyBatis簡(jiǎn)單實(shí)例
MyBatis 本是apache的一個(gè)開源項(xiàng)目iBatis, 2010年這個(gè)項(xiàng)目由apache software foundation 遷移到了google code,并且改名為MyBatis 。本文重點(diǎn)給大家介紹Java持久層框架MyBatis簡(jiǎn)單實(shí)例,非常不錯(cuò),具有參考借鑒價(jià)值,感興趣的朋友一起看下吧2016-07-07
淺談?dòng)肧pringBoot實(shí)現(xiàn)策略模式
本文主要介紹了SpringBoot實(shí)現(xiàn)策略模式,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10
SpringBoot擴(kuò)展SpringMVC原理并實(shí)現(xiàn)全面接管
這篇文章主要介紹了SpringBoot擴(kuò)展SpringMVC原理并實(shí)現(xiàn)全面接管,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11

