前段時間因為團隊調整,大部分時間放在了團隊上,這系列的更新又耽誤了一下。但既然承諾持久更新,那就不會落下,今天開始繼續更新這部分的內容!
過了年,重申一下這個系列的目標:目前主要任務就是把Spring Boot 1.x部分沒有升級的內容做完升級。我會將因為版本升級而產生的變化做一些說明,這樣不論低版本的讀者還是高版本的讀者都能找到自己想要的部分。這也是這次做2.x版本升級的重要原因,儘量避免或減少有讀者用著高版本參考我這邊低版本的實現而出現問題,然後開始問候我家人的情況。
在完成上述所有的更新之後,接下來很重要的更新內容將會集中在關於Spring Boot的一些進階內容,比如:要做什麼擴充套件的時候,該從哪裡著手等。
如果是您是Spring Boot的使用者,那麼一定要關注一下!後面的內容會越來越精彩!
下面迴歸今天的主題,如何在Spring Boot中使用MongoDB!
MongoDB簡介
MongoDB是一個基於分散式檔案儲存的資料庫,它是一個介於關聯式資料庫和非關聯式資料庫之間的產品,其主要目標是在鍵/值儲存方式(提供了高效能和高度伸縮性)和傳統的RDBMS系統(具有豐富的功能)之間架起一座橋樑,它集兩者的優勢於一身。
MongoDB支援的資料結構非常鬆散,是類似json的bson格式,因此可以儲存比較複雜的資料型別,也因為他的儲存格式也使得它所儲存的資料在Nodejs程式應用中使用非常流暢。
既然稱為NoSQL資料庫,Mongo的查詢語言非常強大,其語法有點類似於物件導向的查詢語言,幾乎可以實現類似關聯式資料庫單表查詢的絕大部分功能,而且還支援對資料建立索引。
但是,MongoDB也不是萬能的,同MySQL等關係型資料庫相比,它們在針對不同的資料型別和事務要求上都存在自己獨特的優勢。在資料儲存的選擇中,堅持多樣化原則,選擇更好更經濟的方式,而不是自上而下的統一化。
較常見的,我們可以直接用MongoDB來儲存鍵值對型別的資料,如:驗證碼、Session等;由於MongoDB的橫向擴充套件能力,也可以用來儲存資料規模會在未來變的非常巨大的資料,如:日誌、評論等;由於MongoDB儲存資料的弱型別,也可以用來儲存一些多變json資料,如:與外系統互動時經常變化的JSON報文。而對於一些對資料有複雜的高事務性要求的操作,如:賬戶交易等就不適合使用MongoDB來儲存。
MongoDB官網:https://www.mongodb.org/
動手試試
第一步:引入依賴
Spring Boot中可以通過在pom.xml中加入spring-boot-starter-data-mongodb引入對mongodb的訪問支援依賴。它的實現依賴spring-data-mongodb。是的,您沒有看錯,又是spring-data的子專案,之前介紹過spring-data-jpa、spring-data-redis,對於mongodb的訪問,spring-data也提供了強大的支援,下面就開始動手試試吧。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>
第二步:建立使用者實體User
@Data
public class User {
@Id
private Long id;
private String username;
private Integer age;
}
第三步:實現使用者實體User
的資料訪問物件UserRepository
public interface UserRepository extends MongoRepository<User, Long> {
User findByUsername(String username);
}
在Spring Data的抽象下,是不是同其他Spring Data子專案一樣的簡潔、好用、易學!
第四步:編寫單元測試
@SpringBootTest(classes = Chapter61Application.class)
public class ApplicationTests {
@Autowired
private UserRepository userRepository;
@Test
public void test() throws Exception {
userRepository.deleteAll();
// 建立三個User,並驗證User總數
userRepository.save(new User(1L, "didi", 30));
userRepository.save(new User(2L, "mama", 40));
userRepository.save(new User(3L, "kaka", 50));
Assertions.assertEquals(3, userRepository.findAll().size());
// 刪除一個User,再驗證User總數
User u = userRepository.findById(1L).get();
userRepository.delete(u);
Assertions.assertEquals(2, userRepository.findAll().size());
// 刪除一個User,再驗證User總數
u = userRepository.findByUsername("mama");
userRepository.delete(u);
Assertions.assertEquals(1, userRepository.findAll().size());
}
}
這裡注意所使用的
Assertions
是Spring Boot 2.4之後整合的版本,之前的版本還是使用Assert
第五步:引數配置
通過上面的例子,我們可以輕而易舉的對MongoDB進行訪問,但是實戰中,應用伺服器與MongoDB通常不會部署於同一臺裝置之上,這樣就無法使用自動化的本地配置來進行使用。這個時候,我們也可以方便的配置來完成支援,只需要在application.properties
中加入mongodb服務端的相關配置,具體示例如下:
spring.data.mongodb.uri=mongodb://name:pass@localhost:27017/test
在嘗試此配置時,記得在mongo中對test庫建立具備讀寫許可權的使用者(使用者名稱為name,密碼為pass),不同版本的使用者建立語句不同,注意檢視文件做好準備工作
若使用mongodb 2.x,也可以通過如下引數配置,該方式不支援mongodb 3.x。
spring.data.mongodb.host=localhost spring.data.mongodb.port=27017
題外話
MongoDB雖然在過去的一段時間,收到不少的關注,但由於其在各方面都表現中庸,最近似乎越來越少聽到或者看到關於MongoDB的大規模應用場景。就筆者所接觸的很多以往的使用場景也都開始在使用ES來取代,以獲得更好的效能表現。
所以,下次我們就來講講Spring Boot中如何使用ES吧!關注我,持續獲得更多Spring Boot的技術乾貨!
更多本系列免費教程連載「點選進入彙總目錄」
程式碼示例
本文的相關例子可以檢視下面倉庫中的chapter6-1
目錄:
- Github:https://github.com/dyc87112/SpringBoot-Learning/
- Gitee:https://gitee.com/didispace/SpringBoot-Learning/
如果您覺得本文不錯,歡迎Star
支援,您的關注是我堅持的動力!
歡迎關注我的公眾號:程式猿DD,獲得獨家整理的免費學習資源助力你的Java學習之路!另每週贈書不停哦~