日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Spring Boot 2.5.0 重新設計的spring.sql.init 配置有啥用

瀏覽:191日期:2023-07-14 10:54:46
棄用內容

先來糾正一個誤區。主要之前在版本更新介紹的時候,存在一些表述上的問題。導致部分讀者認為這次的更新是Datasource本身初始化的調整,但其實并不是。這次重新設計的只是對Datasource腳本初始化機制的重新設計。

先來看看這次被棄用部分的內容(位于org.springframework.boot.autoconfigure.jdbc.DataSourceProperties),如果你有用過這些配置內容,那么新配置就很容易理解了。

/** * Mode to apply when determining if DataSource initialization should be performed * using the available DDL and DML scripts. */@Deprecatedprivate DataSourceInitializationMode initializationMode = DataSourceInitializationMode.EMBEDDED;/** * Platform to use in the DDL or DML scripts (such as schema-${platform}.sql or * data-${platform}.sql). */@Deprecatedprivate String platform = 'all';/** * Schema (DDL) script resource references. */private List<String> schema;/** * Username of the database to execute DDL scripts (if different). */@Deprecatedprivate String schemaUsername;/** * Password of the database to execute DDL scripts (if different). */@Deprecatedprivate String schemaPassword;/** * Data (DML) script resource references. */@Deprecatedprivate List<String> data;/** * Username of the database to execute DML scripts (if different). */@Deprecatedprivate String dataUsername;/** * Password of the database to execute DML scripts (if different). */@Deprecatedprivate String dataPassword;/** * Whether to stop if an error occurs while initializing the database. */@Deprecatedprivate boolean continueOnError = false;/** * Statement separator in SQL initialization scripts. */@Deprecatedprivate String separator = ';';/** * SQL scripts encoding. */@Deprecatedprivate Charset sqlScriptEncoding;

對應到配置文件里的屬性如下(這里僅列出部分,就不全部列出了,主要就是對應上面源碼中的屬性):

spring.datasource.schema=spring.datasource.schema-username=spring.datasource.schema-password=...

這些配置主要用來指定數據源初始化之后要用什么用戶、去執行哪些腳本、遇到錯誤是否繼續等功能。

新的設計

Spring Boot 2.5.0開始,啟用了全新的配置方式,我們可以從這個類org.springframework.boot.autoconfigure.sql.init.SqlInitializationProperties里看到詳情。

下面我們通過一個簡單的例子來體驗這個功能的作用。

創建一個Spring Boot的基礎應用,并在pom.xml中引入和mysql的依賴:

<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId></dependency><dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId></dependency>

在配置文件中增加數據源和初始化數據源的配置,具體如下:

spring.datasource.url=jdbc:mysql://localhost:3306/testspring.datasource.username=rootspring.datasource.password=spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver# Spring Boot 2.5.0 init schema & data# 執行初始化腳本的用戶名稱spring.sql.init.username=root# 執行初始化腳本的用戶密碼spring.sql.init.password=# 初始化的schema腳本位置spring.sql.init.schema-locations=classpath*:schema-all.sql

根據上面配置的定義,接下來就在resource目錄下,創建腳本文件schema-all.sql,并寫入一些初始化表結構的腳本

create table test.user_info( id int unsigned auto_increment comment ’用戶id’primary key, open_id varchar(255) default ’’ null comment ’微信小程序openid’, nick_name varchar(255) default ’’ null comment ’微信名’, head_img varchar(255) default ’’ null comment ’微信頭像’, sex varchar(255) default ’’ null comment ’性別’, phone varchar(255) default ’’ null comment ’手機’, province varchar(255) default ’’ null comment ’注冊地址:省’, cityvarchar(255) default ’’ null comment ’注冊地址:城市’, country varchar(255) default ’’ null comment ’注冊地址:縣/區’, status tinyint unsigned default 0 not null comment ’是否標記刪除 0:否 1:是’, create_time datetime not null comment ’創建時間’, update_time datetime not null comment ’更新時間’)comment ’用戶表’;

完成上面步驟之后,啟動應用。然后打開MySQL客戶端,可以看到在test庫下,多了一個user_info表

通過上面的例子,不難想到這樣的功能主要可以用來管理應用啟動與數據庫配置的自動執行,以減少應用部署過程中手工執行的內容,降低應用部署的執行步驟。

配置詳解

除了上面用到的配置屬性之外,還有一些其他的配置,下面詳細講解一下作用。

spring.sql.init.enabled:是否啟動初始化的開關,默認是true。如果不想執行初始化腳本,設置為false即可。通過-D的命令行參數會更容易控制。 spring.sql.init.username和spring.sql.init.password:配置執行初始化腳本的用戶名與密碼。這個非常有必要,因為安全管理要求,通常給業務應用分配的用戶對一些建表刪表等命令沒有權限。這樣就可以與datasource中的用戶分開管理。 spring.sql.init.schema-locations:配置與schema變更相關的sql腳本,可配置多個(默認用;分割) spring.sql.init.data-locations:用來配置與數據相關的sql腳本,可配置多個(默認用;分割) spring.sql.init.encoding:配置腳本文件的編碼 spring.sql.init.separator:配置多個sql文件的分隔符,默認是; spring.sql.init.continue-on-error:如果執行腳本過程中碰到錯誤是否繼續,默認是false`;所以,上面的例子第二次執行的時候會報錯并啟動失敗,因為第一次執行的時候表已經存在。應用建議

關于這些配置的應用,相信聰明的你一定會把它與數據庫的版本管理聯系起來(因為可以自動的執行腳本)。

那么依靠這些配置,是否可以勝任業務應用部署時候數據庫初始化的自動化實現呢?

個人認為就上述所介紹的配置,雖然具備了一定的自動執行能力。但由于缺失對當前環境的判斷能力,所以要應對實際的部署場景來說,還是遠遠不夠的。

如果要自動化的管理數據庫表結構、初始化數據的話,我的建議是:

默認提供的這個初始化功能可以且僅用于單元測試,自動創建數據庫結構與初始化數據,使用完畢后銷毀。可以方便的控制每次單元測試的執行環境一致。 應用在環境部署的時候,還是要使用之前介紹過的Flyway來實現,如何使用可見之前的分享:使用Flyway來管理數據庫版本。 聯合Flyway一同使用,通過org.springframework.jdbc.datasource.init.DataSourceInitializer來定義更復雜的執行邏輯。

更多本系列免費教程連載「點擊進入匯總目錄」

代碼示例

本文的相關例子可以查看下面倉庫中的chapter3-13目錄:

Github:https://github.com/dyc87112/SpringBoot-Learning/

Gitee:https://gitee.com/didispace/SpringBoot-Learning/

到此這篇關于Spring Boot 2.5.0 重新設計的spring.sql.init 配置有啥用?的文章就介紹到這了,更多相關spring.sql.init 配置內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产色99精品9i| 99免费精品| 亚洲女同一区| 国产精品99视频| 99精品小视频| 日本大胆欧美人术艺术动态| 私拍精品福利视频在线一区| 99国产精品免费视频观看| 99久久久久国产精品| 亚洲欧美高清| 日韩成人一级| 国产精品第一| 欧美成人基地| 福利在线一区| 伊人久久大香线蕉av超碰演员| 国产精品日本欧美一区二区三区| 日本中文字幕一区二区视频| 久久99蜜桃| 亚洲福利精品| 影音先锋久久精品| 亚州精品视频| 国产精品一区二区三区www| 国产在线日韩| 综合干狼人综合首页| 自拍日韩欧美| 国产精品激情| 国产免费播放一区二区| 国产66精品| 日本特黄久久久高潮| 国产一区二区三区精品在线观看| 99精品在线免费在线观看| 亚洲涩涩在线| 7777精品| 免费美女久久99| 中文av在线全新| 欧美日韩1区| 九九久久婷婷| 色婷婷色综合| 97se亚洲| 中文字幕亚洲精品乱码| 亚洲成a人片| 神马午夜久久| 国产亚洲高清在线观看| 成人片免费看| 国产精品一二| 日韩网站在线| 久久男人天堂| 日韩中文字幕av电影| 亚洲网址在线观看| 91看片一区| sm捆绑调教国产免费网站在线观看| 亚洲精品一级| 99久久精品国产亚洲精品| 涩涩av在线| 精品久久国产一区| 久久精品亚洲一区二区| 亚洲精品免费观看| 国产美女一区| 亚洲精品日韩久久| 国产乱论精品| 日韩av二区在线播放| 亚洲一区欧美| 综合干狼人综合首页| 999国产精品| 国产精品一区二区三区四区在线观看| 国产亚洲综合精品| 麻豆精品91| 国产91一区| 女生影院久久| 91精品推荐| 99视频精品| 亚洲国内欧美| 悠悠资源网久久精品| 久久毛片亚洲| 香蕉久久久久久久av网站| 日本三级亚洲精品| 日韩va亚洲va欧美va久久| 久久国产欧美日韩精品| 欧美一区久久| www在线观看黄色| 狠狠色综合网| 日韩专区欧美专区| 久久在线91| 久久久久久色| 国产一区二区三区成人欧美日韩在线观看| 欧美交a欧美精品喷水| 国产亚洲观看| 欧美日韩一区二区三区视频播放| 亚洲精品va| 精品国产精品国产偷麻豆| 日韩精品一级| 国内精品伊人| 国产一区成人| 免费看av不卡| 99国产一区| 精品香蕉视频| 亚洲精品裸体| 高清不卡亚洲| 国产亚洲观看| 一本一本久久| 国产91在线播放精品| 国产精品久久久久久模特| 日韩精品永久网址| 日韩中文字幕| 欧美sss在线视频| 国产欧美日韩精品一区二区免费| 日韩欧美视频专区| 青草综合视频| 亚洲综合不卡| 日韩不卡在线| sm捆绑调教国产免费网站在线观看| 综合亚洲色图| 国产乱人伦精品一区| 亚洲综合二区| 一区二区91| 91欧美极品| 欧美一级二级视频| 国产精品日本一区二区三区在线| 国产精品一页| 97人人精品| 五月婷婷六月综合| 免费成人性网站| 日韩精品91亚洲二区在线观看| 青草国产精品| 理论片午夜视频在线观看| 激情久久中文字幕| 亚洲一区二区三区久久久| 日韩在线麻豆| 美女视频网站久久| 欧美色图一区| 色综合视频一区二区三区日韩 | 久久最新视频| 国产精选久久| 日韩在线短视频| 免费在线观看不卡| 国产精久久久| 在线精品小视频| 国产精品尤物| japanese国产精品| 日本午夜免费一区二区 | 国产精品99一区二区| 午夜精品亚洲| 麻豆国产欧美日韩综合精品二区| 欧美日韩一区二区三区视频播放| 天堂精品久久久久| 丝袜美腿一区| 国产欧美三级| 久久av一区| 视频福利一区| 国产精品久久久久久模特| 在线视频亚洲| 伊人久久在线| 日韩福利视频网| 欧美日韩国产综合网| 国产精品亚洲片在线播放| 蜜桃tv一区二区三区| 日韩中文字幕| 香蕉久久久久久久av网站| 国产一区二区三区四区大秀| 最新亚洲国产| 在线综合视频| 亚洲v在线看| 久久男人天堂| 国产 日韩 欧美 综合 一区 | 日本成人中文字幕在线视频| 国产一区二区三区自拍| 亚洲精品一级二级| 国产一区二区三区黄网站| 国产精品久久久久久妇女| 久久午夜精品一区二区| 国产高清一区| 色爱综合av| 亚洲福利久久| 国产精品av久久久久久麻豆网| 欧美日韩免费看片| 久久久久久久欧美精品| 91亚洲无吗| 日本91福利区| 日韩精品中文字幕吗一区二区| 久久香蕉精品| 夜夜嗨网站十八久久| 亚洲欧美日韩精品一区二区| 免费看的黄色欧美网站| 蜜桃视频在线观看一区二区| 蜜桃免费网站一区二区三区| 日韩在线网址| 欧美精品aa| 亚洲国产欧美日本视频| 日韩啪啪电影网| 日韩一级精品| 亚洲精品影院在线观看| 欧美一区91| 日本不卡免费高清视频在线| 国内亚洲精品| 日韩激情一区二区| 国产精品流白浆在线观看| 91一区二区| 日韩一区精品视频| 国产精品日本一区二区三区在线| 日韩1区在线|