SpringBoot分布式文件存儲數(shù)據(jù)庫mongod
MongoDB 是一個基于分布式文件存儲的數(shù)據(jù)庫。由 C++ 語言編寫,旨在為 WEB 應(yīng)用提供可擴(kuò)展的高性能數(shù)據(jù)存儲解決方案。
MongoDB 是一個介于關(guān)系數(shù)據(jù)庫和非關(guān)系數(shù)據(jù)庫之間的產(chǎn)品,是非關(guān)系數(shù)據(jù)庫當(dāng)中功能最豐富,最像關(guān)系數(shù)據(jù)庫的。
1、mongodb服務(wù)
mongodb的安裝支持windows和linux等平臺,具體在不同平臺的下載安裝請查看相關(guān)大佬博文。
2、創(chuàng)建springboot項目
此處通過idea工具創(chuàng)建,springboot選擇2.7.0版本,具體不再描述。
3、添加mongodb依賴
Spring Data MongDB 是Spring Data的下的一個模塊,在springboot中整合mongodb就需要添加Spring Data MongDB的依賴,添加Spring Data MongDB依賴的方式有兩種:
創(chuàng)建springboot項目時勾選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ù)庫(集合)
authentication-database: admin # 登錄認(rèn)證的邏輯庫名
username: admin #用戶名
password: abc123456 #密碼
mongodb數(shù)據(jù)庫與mysql不一樣 mysql 一個普通用戶可以管理多個數(shù)據(jù)庫,但是mongo每一個庫都有一個獨(dú)立的管理用戶,連接時需要輸入對應(yīng)用戶密碼。
5、實(shí)體類
@Data
@Document(collection = "article") //指定要對應(yīng)的文檔名(表名)
@Accessors(chain = true) //鏈?zhǔn)皆L問
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ù)單元,由鍵值對組成,類似于 JSON 格式,可以存儲不同字段,字段的值可以包括其他文檔,數(shù)組和文檔數(shù)組;
- @Id(主鍵):用來將成員變量的值映射為文檔的_id的值;
- @Indexed(索引): 索引是一種特殊的數(shù)據(jù)結(jié)構(gòu),存儲在一個易于遍歷讀取的數(shù)據(jù)集合中,能夠?qū)?shù)據(jù)庫文檔中的數(shù)據(jù)進(jìn)行排序。索引能極大提高文檔查詢效率,如果沒有設(shè)置索引,MongoDB 會遍歷集合中的整個文檔,選取符合查詢條件的文檔記錄。這種查詢效率是非常低的;
- @Field(字段): 文檔中的字段,類似于 MySql 中的列;
- @Aggregation(聚合): 聚合主要用于數(shù)據(jù)處理,例如統(tǒng)計平均值、求和等;
6、通過MongoRepository實(shí)現(xiàn)增刪改查
持久層繼承MongoRepository
public interface ArticleRepository extends MongoRepository<Article,String> {
/**
* 根據(jù)id查詢文章
* @param id
* @return
*/
List<Article> findByid(String id);
}
注意,接口需要起名findBy + 主鍵名,否則會報找不到屬性的錯誤。
業(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、通過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 "圖書創(chuàng)建成功";
} else {
return "圖書創(chuàng)建失敗";
}
}
@PostMapping("/delete")
public String delete(@RequestParam("id") String id) {
int count = bookService.delete(id);
if (count > 0) {
return "刪除了" + count + "篇圖書";
} else {
return "刪除圖書失敗";
}
}
@PostMapping("/get")
public Book get(String id) {
Book book = bookService.get(id);
return book;
}
}
注意:通過mongoTemplate查詢時,實(shí)體類的id字段類型需為String類型,否則查詢?yōu)閚ull。
8、測試
通過postman工具測試
創(chuàng)建文章和圖書,分布對應(yīng)兩種方式


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


查詢文章和圖書


刪除文章和圖書


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

