SpringBoot分布式文件存儲(chǔ)數(shù)據(jù)庫(kù)mongod
MongoDB 是一個(gè)基于分布式文件存儲(chǔ)的數(shù)據(jù)庫(kù)。由 C++ 語(yǔ)言編寫(xiě),旨在為 WEB 應(yīng)用提供可擴(kuò)展的高性能數(shù)據(jù)存儲(chǔ)解決方案。
MongoDB 是一個(gè)介于關(guān)系數(shù)據(jù)庫(kù)和非關(guān)系數(shù)據(jù)庫(kù)之間的產(chǎn)品,是非關(guān)系數(shù)據(jù)庫(kù)當(dāng)中功能最豐富,最像關(guān)系數(shù)據(jù)庫(kù)的。
1、mongodb服務(wù)
mongodb的安裝支持windows和linux等平臺(tái),具體在不同平臺(tái)的下載安裝請(qǐng)查看相關(guān)大佬博文。
2、創(chuàng)建springboot項(xiàng)目
此處通過(guò)idea工具創(chuàng)建,springboot選擇2.7.0版本,具體不再描述。
3、添加mongodb依賴
Spring Data MongDB 是Spring Data的下的一個(gè)模塊,在springboot中整合mongodb就需要添加Spring Data MongDB的依賴,添加Spring Data MongDB依賴的方式有兩種:
創(chuàng)建springboot項(xiàng)目時(shí)勾選Spring Data MongoDB

在pom.xml文件中添加Spring Data MongoDB依賴
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>
4、application.yml配置
spring:
data:
mongodb:
uri: mongodb://127.0.0.1:27017/mongodb_test
或
spring:
data:
mongodb:
host: 127.0.0.1 #指定MongoDB服務(wù)地址
port: 27017 #指定端口,默認(rèn)就為27017
database: mongodb #指定使用的數(shù)據(jù)庫(kù)(集合)
authentication-database: admin # 登錄認(rèn)證的邏輯庫(kù)名
username: admin #用戶名
password: abc123456 #密碼
mongodb數(shù)據(jù)庫(kù)與mysql不一樣 mysql 一個(gè)普通用戶可以管理多個(gè)數(shù)據(jù)庫(kù),但是mongo每一個(gè)庫(kù)都有一個(gè)獨(dú)立的管理用戶,連接時(shí)需要輸入對(duì)應(yīng)用戶密碼。
5、實(shí)體類
@Data
@Document(collection = "article") //指定要對(duì)應(yīng)的文檔名(表名)
@Accessors(chain = true) //鏈?zhǔn)皆L問(wèn)
public class Article {
/**
* 文章主鍵
*/
@Id
private String id;
/**
* 文章名
*/
private String name;
/**
* 文章內(nèi)容
*/
private String content;
}
@Data
@Document(collection = "book")
public class Book {
@Id
private String id;
private String name;
private String type;
private String description;
}
其中注解含義如下:
- @Document,文檔是 MongoDB 中最基本的數(shù)據(jù)單元,由鍵值對(duì)組成,類似于 JSON 格式,可以存儲(chǔ)不同字段,字段的值可以包括其他文檔,數(shù)組和文檔數(shù)組;
- @Id(主鍵):用來(lái)將成員變量的值映射為文檔的_id的值;
- @Indexed(索引): 索引是一種特殊的數(shù)據(jù)結(jié)構(gòu),存儲(chǔ)在一個(gè)易于遍歷讀取的數(shù)據(jù)集合中,能夠?qū)?shù)據(jù)庫(kù)文檔中的數(shù)據(jù)進(jìn)行排序。索引能極大提高文檔查詢效率,如果沒(méi)有設(shè)置索引,MongoDB 會(huì)遍歷集合中的整個(gè)文檔,選取符合查詢條件的文檔記錄。這種查詢效率是非常低的;
- @Field(字段): 文檔中的字段,類似于 MySql 中的列;
- @Aggregation(聚合): 聚合主要用于數(shù)據(jù)處理,例如統(tǒng)計(jì)平均值、求和等;
6、通過(guò)MongoRepository實(shí)現(xiàn)增刪改查
持久層繼承MongoRepository
public interface ArticleRepository extends MongoRepository<Article,String> {
/**
* 根據(jù)id查詢文章
* @param id
* @return
*/
List<Article> findByid(String id);
}
注意,接口需要起名findBy + 主鍵名,否則會(huì)報(bào)找不到屬性的錯(cuò)誤。
業(yè)務(wù)層
@Service
@RequiredArgsConstructor
public class ArticleService {
private final ArticleRepository articleRepository;
/**
* 添加文章
*
* @param article
* @return
*/
public int create(Article article) {
Article save = articleRepository.save(article);
return 1;
}
/**
* 刪除文章
*
* @param ids
*/
public int delete(List<String> ids) {
List<Article> deleteList = new ArrayList<>();
for(String id:ids){
Article article = new Article();
article.setId(id);
deleteList.add(article);
}
articleRepository.deleteAll(deleteList);
return ids.size();
}
/**
* 查詢文章
* @param id
* @return
*/
public List<Article> get(String id) {
return articleRepository.findByid(id);
}
}
控制層
@RestController
@RequestMapping("/article")
@RequiredArgsConstructor
public class ArticleController {
private final ArticleService articleService;
@PostMapping("/create")
public String create(@RequestBody Article article) {
int result = articleService.create(article);
if (result > 0) {
return "文章創(chuàng)建成功";
} else {
return "文章創(chuàng)建失敗";
}
}
@PostMapping("/delete")
public String delete(@RequestParam("ids") List<String> ids) {
int count = articleService.delete(ids);
if (count > 0) {
return "刪除了" + count + "篇文章";
} else {
return "刪除文章失敗";
}
}
@PostMapping("/get")
public List<Article> get(String id) {
List<Article> list = articleService.get(id);
return list;
}
}
7、通過(guò)MongoTemplate實(shí)現(xiàn)增刪改查
業(yè)務(wù)層
@Service
@RequiredArgsConstructor
public class BookService {
private final MongoTemplate mongoTemplate;
/**
* 添加文章
*
* @param book
* @return
*/
public int create(Book book) {
Book save = mongoTemplate.save(book);
return 1;
}
/**
* 刪除文章
*
* @param id
*/
public int delete(String id) {
List<Book> deleteList = new ArrayList<>();
Query query = new Query();
query.addCriteria(Criteria.where("id").is(id));
mongoTemplate.remove(query,Book.class);
return 1;
}
/**
* 查詢文章
* @param id
* @return
*/
public Book get(String id) {
Book byId = mongoTemplate.findById(id, Book.class);
return byId;
}
}
控制層
@RestController
@RequestMapping("/book")
@RequiredArgsConstructor
public class BookController {
private final BookService bookService;
@PostMapping("/create")
public String create(@RequestBody Book book) {
int result = bookService.create(book);
if (result > 0) {
return "圖書(shū)創(chuàng)建成功";
} else {
return "圖書(shū)創(chuàng)建失敗";
}
}
@PostMapping("/delete")
public String delete(@RequestParam("id") String id) {
int count = bookService.delete(id);
if (count > 0) {
return "刪除了" + count + "篇圖書(shū)";
} else {
return "刪除圖書(shū)失敗";
}
}
@PostMapping("/get")
public Book get(String id) {
Book book = bookService.get(id);
return book;
}
}
注意:通過(guò)mongoTemplate查詢時(shí),實(shí)體類的id字段類型需為String類型,否則查詢?yōu)閚ull。
8、測(cè)試
通過(guò)postman工具測(cè)試
創(chuàng)建文章和圖書(shū),分布對(duì)應(yīng)兩種方式


數(shù)據(jù)庫(kù)中記錄如下


查詢文章和圖書(shū)


刪除文章和圖書(shū)


到此這篇關(guān)于SpringBoot分布式文件存儲(chǔ)數(shù)據(jù)庫(kù)mongod的文章就介紹到這了,更多相關(guān)SpringBoot mongod內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Go使用Redis實(shí)現(xiàn)分布式鎖的常見(jiàn)方法
- Golang使用Zookeeper實(shí)現(xiàn)分布式鎖
- Go分布式鏈路追蹤實(shí)戰(zhàn)探索
- 分布式架構(gòu)在Go語(yǔ)言網(wǎng)站的應(yīng)用
- Golang微服務(wù)框架Kratos實(shí)現(xiàn)分布式任務(wù)隊(duì)列Asynq的方法詳解
- 基于Golang實(shí)現(xiàn)Redis分布式鎖解決秒殺問(wèn)題
- 用Go語(yǔ)言編寫(xiě)一個(gè)簡(jiǎn)單的分布式系統(tǒng)
- Go語(yǔ)言使用Etcd實(shí)現(xiàn)分布式鎖
- 在Go語(yǔ)言開(kāi)發(fā)中實(shí)現(xiàn)高性能的分布式日志收集的方法
相關(guān)文章
Nacos后臺(tái)頻繁打印get changedGroupKeys:[]的問(wèn)題及解決
這篇文章主要介紹了Nacos后臺(tái)頻繁打印get changedGroupKeys:[]的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
JVM對(duì)象創(chuàng)建和內(nèi)存分配原理解析
這篇文章主要介紹了JVM對(duì)象創(chuàng)建和內(nèi)存分配原理解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02
SpringMVC配置多個(gè)properties文件之通配符解析
這篇文章主要介紹了SpringMVC配置多個(gè)properties文件之通配符解析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09
SpringBoot+Hutool+thymeleaf完成導(dǎo)出Excel的實(shí)現(xiàn)方法
這篇文章主要介紹了SpringBoot+Hutool+thymeleaf完成導(dǎo)出Excel,本篇示例當(dāng)中不僅僅有后端,而且還提供了前端html,html當(dāng)中利用js將后端 輸出流直接下載為文件,需要的朋友可以參考下2022-03-03
SpringBoot +Vue開(kāi)發(fā)考試系統(tǒng)的教程
這篇文章主要介紹了SpringBoot +Vue開(kāi)發(fā)考試系統(tǒng),支持多種題型:選擇題、多選題、判斷題、填空題、綜合題以及數(shù)學(xué)公式。支持在線考試,教師在線批改試卷。本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2020-05-05
Java實(shí)現(xiàn)用戶短信驗(yàn)證碼登錄功能實(shí)例代碼
現(xiàn)在不管是各類的網(wǎng)站,還是大小社交app,登錄方式是越來(lái)越多了,但是大部分還是以短信登錄為主,本文主要介紹了java短信驗(yàn)證碼登錄功能設(shè)計(jì)與實(shí)現(xiàn),感興趣的可以了解一下2021-11-11
RestTemplate 401 獲取錯(cuò)誤信息的處理方案
這篇文章主要介紹了RestTemplate 401 獲取錯(cuò)誤信息的處理方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08
Spring中@ExceptionHandler注解的工作原理詳解
這篇文章主要介紹了Spring中@ExceptionHandler注解的工作原理詳解,Spring Web注解@ExceptionHandler可以用來(lái)指定處理某類異常的控制器方法,從而在這些異常發(fā)生時(shí),會(huì)有相應(yīng)的控制器方法來(lái)處理此類異常,需要的朋友可以參考下2024-01-01

