Spring Boot (十三): Spring Boot 小技巧

一些 Spring Boot 小技巧、小知識點html

初始化數據

咱們在作測試的時候常常須要初始化導入一些數據,如何來處理呢?會有兩種選擇,一種是使用 Jpa,另一種是 Spring JDBC 。兩種方式各有區別下面來詳細介紹。git

使用 Jpagithub

在使用spring boot jpa的狀況下設置spring.jpa.hibernate.ddl-auto的屬性設置爲 create or create-drop的時候,Spring Boot 啓動時默認會掃描 classpath 下面(項目中通常是 resources 目錄)是否有import.sql,若是有機會執行import.sql腳本。spring

使用 Spring JDBC sql

使用 Spring JDBC 須要在配置文件中添加如下配置數據庫

spring:
    datasource:
      schema: database/data.sql
      sql-script-encoding: utf-8
    jpa:
      hibernate:
        ddl-auto: none
  • schema :設置腳本的路徑
  • sql-script-encoding:設置腳本的編碼

Spring Boot 項目啓動的時候會自動執行腳本。服務器

ddl-auto 四個值的解釋session

  1. create: 每次加載hibernate時都會刪除上一次的生成的表,而後根據你的model類再從新來生成新表,哪怕兩次沒有任何改變也要這樣執行,這就是致使數據庫表數據丟失的一個重要緣由。
  2. create-drop :每次加載hibernate時根據model類生成表,可是sessionFactory一關閉,表就自動刪除。
  3. update:最經常使用的屬性,第一次加載hibernate時根據model類會自動創建起表的結構(前提是先創建好數據庫),之後加載hibernate時根據 model類自動更新表結構,即便表結構改變了但表中的行仍然存在不會刪除之前的行。要注意的是當部署到服務器後,表結構是不會被立刻創建起來的,是要等 應用第一次運行起來後纔會。
  4. validate :每次加載hibernate時,驗證建立數據庫表結構,只會和數據庫中的表進行比較,不會建立新表,可是會插入新值。
    五、 none : 什麼都不作。

不一樣點spring-boot

第一種方式啓動的時候 Jpa 會自動建立表,import.sql 只負責建立表單後的初始化數據。第二種方式啓動的時候不會建立表,須要在初始化腳本中判斷表是否存在,再初始化腳本的步驟。工具

在生產中,這兩種模式都建議慎用!

Thymeleaf 設置不校驗 html 標籤

默認配置下,Thymeleaf 對 .html 的內容要求很嚴格,好比<meta charset="UTF-8" />,若是少封閉符號/,就會報錯而轉到錯誤頁。也好比你在使用 Vue.js 這樣的庫,而後有<div v-cloak></div>這樣的 html 代碼,也會被 Thymeleaf 認爲不符合要求而拋出錯誤。

經過設置 Thymeleaf 模板能夠解決這個問題,下面是具體的配置:

spring.thymeleaf.cache=false
spring.thymeleaf.mode=LEGACYHTML5

LEGACYHTML5 須要搭配一個額外的庫 NekoHTML 纔可用,項目中使用的構建工具是 Maven 添加以下的依賴便可完成:

<dependency>
    <groupId>net.sourceforge.nekohtml</groupId>
    <artifactId>nekohtml</artifactId>
    <version>1.9.22</version>
</dependency>

文章內容已經升級到 Spring Boot 2.x

示例代碼-github

示例代碼-碼雲

參考:

相關文章
相關標籤/搜索