SpringBoot分布式文件存儲數(shù)據(jù)庫mongod
MongoDB 是一個基于分布式文件存儲的數(shù)據(jù)庫。由 C++ 語言編寫,旨在為 WEB 應用提供可擴展的高性能數(shù)據(jù)存儲解決方案。
MongoDB 是一個介于關系數(shù)據(jù)庫和非關系數(shù)據(jù)庫之間的產(chǎn)品,是非關系數(shù)據(jù)庫當中功能最豐富,最像關系數(shù)據(jù)庫的。
1、mongodb服務
mongodb的安裝支持windows和linux等平臺,具體在不同平臺的下載安裝請查看相關大佬博文。
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服務地址
port: 27017 #指定端口,默認就為27017
database: mongodb #指定使用的數(shù)據(jù)庫(集合)
authentication-database: admin # 登錄認證的邏輯庫名
username: admin #用戶名
password: abc123456 #密碼
mongodb數(shù)據(jù)庫與mysql不一樣 mysql 一個普通用戶可以管理多個數(shù)據(jù)庫,但是mongo每一個庫都有一個獨立的管理用戶,連接時需要輸入對應用戶密碼。
5、實體類
@Data @Document(collection = "article") //指定要對應的文檔名(表名) @Accessors(chain = true) //鏈式訪問 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é)構,存儲在一個易于遍歷讀取的數(shù)據(jù)集合中,能夠?qū)?shù)據(jù)庫文檔中的數(shù)據(jù)進行排序。索引能極大提高文檔查詢效率,如果沒有設置索引,MongoDB 會遍歷集合中的整個文檔,選取符合查詢條件的文檔記錄。這種查詢效率是非常低的;
- @Field(字段): 文檔中的字段,類似于 MySql 中的列;
- @Aggregation(聚合): 聚合主要用于數(shù)據(jù)處理,例如統(tǒng)計平均值、求和等;
6、通過MongoRepository實現(xiàn)增刪改查
持久層繼承MongoRepository
public interface ArticleRepository extends MongoRepository<Article,String> { /** * 根據(jù)id查詢文章 * @param id * @return */ List<Article> findByid(String id); }
注意,接口需要起名findBy + 主鍵名,否則會報找不到屬性的錯誤。
業(yè)務層
@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實現(xiàn)增刪改查
業(yè)務層
@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查詢時,實體類的id字段類型需為String類型,否則查詢?yōu)閚ull。
8、測試
通過postman工具測試
創(chuàng)建文章和圖書,分布對應兩種方式
數(shù)據(jù)庫中記錄如下
查詢文章和圖書
刪除文章和圖書
到此這篇關于SpringBoot分布式文件存儲數(shù)據(jù)庫mongod的文章就介紹到這了,更多相關SpringBoot mongod內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Nacos后臺頻繁打印get changedGroupKeys:[]的問題及解決
這篇文章主要介紹了Nacos后臺頻繁打印get changedGroupKeys:[]的問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01SpringMVC配置多個properties文件之通配符解析
這篇文章主要介紹了SpringMVC配置多個properties文件之通配符解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09SpringBoot+Hutool+thymeleaf完成導出Excel的實現(xiàn)方法
這篇文章主要介紹了SpringBoot+Hutool+thymeleaf完成導出Excel,本篇示例當中不僅僅有后端,而且還提供了前端html,html當中利用js將后端 輸出流直接下載為文件,需要的朋友可以參考下2022-03-03SpringBoot +Vue開發(fā)考試系統(tǒng)的教程
這篇文章主要介紹了SpringBoot +Vue開發(fā)考試系統(tǒng),支持多種題型:選擇題、多選題、判斷題、填空題、綜合題以及數(shù)學公式。支持在線考試,教師在線批改試卷。本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2020-05-05Spring中@ExceptionHandler注解的工作原理詳解
這篇文章主要介紹了Spring中@ExceptionHandler注解的工作原理詳解,Spring Web注解@ExceptionHandler可以用來指定處理某類異常的控制器方法,從而在這些異常發(fā)生時,會有相應的控制器方法來處理此類異常,需要的朋友可以參考下2024-01-01