SpringBoot分布式文件存儲(chǔ)數(shù)據(jù)庫(kù)mongod
MongoDB 是一個(gè)基于分布式文件存儲(chǔ)的數(shù)據(jù)庫(kù)。由 C++ 語言編寫,旨在為 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)目
此處通過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問 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(主鍵):用來將成員變量的值映射為文檔的_id的值;
- @Indexed(索引): 索引是一種特殊的數(shù)據(jù)結(jié)構(gòu),存儲(chǔ)在一個(gè)易于遍歷讀取的數(shù)據(jù)集合中,能夠?qū)?shù)據(jù)庫(kù)文檔中的數(shù)據(jù)進(jìn)行排序。索引能極大提高文檔查詢效率,如果沒有設(shè)置索引,MongoDB 會(huì)遍歷集合中的整個(gè)文檔,選取符合查詢條件的文檔記錄。這種查詢效率是非常低的;
- @Field(字段): 文檔中的字段,類似于 MySql 中的列;
- @Aggregation(聚合): 聚合主要用于數(shù)據(jù)處理,例如統(tǒng)計(jì)平均值、求和等;
6、通過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、通過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í),實(shí)體類的id字段類型需為String類型,否則查詢?yōu)閚ull。
8、測(cè)試
通過postman工具測(cè)試
創(chuàng)建文章和圖書,分布對(duì)應(yīng)兩種方式
數(shù)據(jù)庫(kù)中記錄如下
查詢文章和圖書
刪除文章和圖書
到此這篇關(guān)于SpringBoot分布式文件存儲(chǔ)數(shù)據(jù)庫(kù)mongod的文章就介紹到這了,更多相關(guān)SpringBoot mongod內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(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ù)隊(duì)列Asynq的方法詳解
- 基于Golang實(shí)現(xiàn)Redis分布式鎖解決秒殺問題
- 用Go語言編寫一個(gè)簡(jiǎn)單的分布式系統(tǒng)
- Go語言使用Etcd實(shí)現(xiàn)分布式鎖
- 在Go語言開發(fā)中實(shí)現(xiàn)高性能的分布式日志收集的方法
相關(guān)文章
Nacos后臺(tái)頻繁打印get changedGroupKeys:[]的問題及解決
這篇文章主要介紹了Nacos后臺(tái)頻繁打印get changedGroupKeys:[]的問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01JVM對(duì)象創(chuàng)建和內(nèi)存分配原理解析
這篇文章主要介紹了JVM對(duì)象創(chuàng)建和內(nèi)存分配原理解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02SpringMVC配置多個(gè)properties文件之通配符解析
這篇文章主要介紹了SpringMVC配置多個(gè)properties文件之通配符解析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09SpringBoot+Hutool+thymeleaf完成導(dǎo)出Excel的實(shí)現(xiàn)方法
這篇文章主要介紹了SpringBoot+Hutool+thymeleaf完成導(dǎo)出Excel,本篇示例當(dāng)中不僅僅有后端,而且還提供了前端html,html當(dāng)中利用js將后端 輸出流直接下載為文件,需要的朋友可以參考下2022-03-03SpringBoot +Vue開發(fā)考試系統(tǒng)的教程
這篇文章主要介紹了SpringBoot +Vue開發(fā)考試系統(tǒng),支持多種題型:選擇題、多選題、判斷題、填空題、綜合題以及數(shù)學(xué)公式。支持在線考試,教師在線批改試卷。本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2020-05-05Java實(shí)現(xiàn)用戶短信驗(yàn)證碼登錄功能實(shí)例代碼
現(xiàn)在不管是各類的網(wǎng)站,還是大小社交app,登錄方式是越來越多了,但是大部分還是以短信登錄為主,本文主要介紹了java短信驗(yàn)證碼登錄功能設(shè)計(jì)與實(shí)現(xiàn),感興趣的可以了解一下2021-11-11RestTemplate 401 獲取錯(cuò)誤信息的處理方案
這篇文章主要介紹了RestTemplate 401 獲取錯(cuò)誤信息的處理方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08Spring中@ExceptionHandler注解的工作原理詳解
這篇文章主要介紹了Spring中@ExceptionHandler注解的工作原理詳解,Spring Web注解@ExceptionHandler可以用來指定處理某類異常的控制器方法,從而在這些異常發(fā)生時(shí),會(huì)有相應(yīng)的控制器方法來處理此類異常,需要的朋友可以參考下2024-01-01