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

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:184日期:2023-07-14 10:54:46
棄用內(nèi)容

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

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

/** * 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;

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

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

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

新的設(shè)計

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

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

創(chuàng)建一個Spring Boot的基礎(chǔ)應(yīng)用,并在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>

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

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# 執(zhí)行初始化腳本的用戶名稱spring.sql.init.username=root# 執(zhí)行初始化腳本的用戶密碼spring.sql.init.password=# 初始化的schema腳本位置spring.sql.init.schema-locations=classpath*:schema-all.sql

根據(jù)上面配置的定義,接下來就在resource目錄下,創(chuàng)建腳本文件schema-all.sql,并寫入一些初始化表結(jié)構(gòu)的腳本

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 ’注冊地址:縣/區(qū)’, status tinyint unsigned default 0 not null comment ’是否標(biāo)記刪除 0:否 1:是’, create_time datetime not null comment ’創(chuàng)建時間’, update_time datetime not null comment ’更新時間’)comment ’用戶表’;

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

通過上面的例子,不難想到這樣的功能主要可以用來管理應(yīng)用啟動與數(shù)據(jù)庫配置的自動執(zhí)行,以減少應(yīng)用部署過程中手工執(zhí)行的內(nèi)容,降低應(yīng)用部署的執(zhí)行步驟。

配置詳解

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

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

關(guān)于這些配置的應(yīng)用,相信聰明的你一定會把它與數(shù)據(jù)庫的版本管理聯(lián)系起來(因為可以自動的執(zhí)行腳本)。

那么依靠這些配置,是否可以勝任業(yè)務(wù)應(yīng)用部署時候數(shù)據(jù)庫初始化的自動化實現(xiàn)呢?

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

如果要自動化的管理數(shù)據(jù)庫表結(jié)構(gòu)、初始化數(shù)據(jù)的話,我的建議是:

默認(rèn)提供的這個初始化功能可以且僅用于單元測試,自動創(chuàng)建數(shù)據(jù)庫結(jié)構(gòu)與初始化數(shù)據(jù),使用完畢后銷毀??梢苑奖愕目刂泼看螁卧獪y試的執(zhí)行環(huán)境一致。 應(yīng)用在環(huán)境部署的時候,還是要使用之前介紹過的Flyway來實現(xiàn),如何使用可見之前的分享:使用Flyway來管理數(shù)據(jù)庫版本。 聯(lián)合Flyway一同使用,通過org.springframework.jdbc.datasource.init.DataSourceInitializer來定義更復(fù)雜的執(zhí)行邏輯。

更多本系列免費教程連載「點擊進入?yún)R總目錄」

代碼示例

本文的相關(guān)例子可以查看下面?zhèn)}庫中的chapter3-13目錄:

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

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

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

標(biāo)簽: Spring
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产极品久久久久久久久波多结野| 亚洲免费福利| 色88888久久久久久影院| 韩国女主播一区二区三区| 欧美一级二区| 久久99青青| 精品一区二区三区四区五区| 国产suv精品一区二区四区视频| 日韩av有码| 麻豆国产在线| 欧美亚洲国产激情| 久久国产福利| 日本午夜免费一区二区| 国产精品1luya在线播放| 国产在视频一区二区三区吞精| 高清久久精品| 久久精品国产亚洲夜色av网站| 99热精品在线| 日本精品另类| 国产日产一区| 久久免费精品| 欧美日韩国产v| 99亚洲视频| 日韩不卡在线观看日韩不卡视频| 日本少妇精品亚洲第一区| 免费亚洲婷婷| 国产区精品区| 黄色国产精品| 欧美另类中文字幕 | 久久久蜜桃一区二区人| 久久精品一区二区国产| 国产欧美一区二区精品久久久 | 黄色在线观看www| 久久精品不卡| 亚洲精品一二三**| 麻豆国产欧美一区二区三区| 黄色aa久久| 伊人久久成人| 精品国产亚洲日本| 欧美一区久久| 成人午夜在线| 亚洲女同一区| 涩涩涩久久久成人精品| 国产精品九九| 91精品亚洲| 日韩一区二区三区高清在线观看 | 国产乱码精品一区二区三区亚洲人| 精品美女视频| 亚洲在线一区| 国产毛片精品| 成人小电影网站| 日本国产欧美| 日韩中文一区二区| 日韩精品一区第一页| 中国女人久久久| 999久久久精品国产| 少妇久久久久| 夜夜精品视频| 国产精品videossex久久发布 | 日韩av在线免费观看不卡| 国产videos久久| 免费观看在线综合| 人在线成免费视频| 青青青国产精品| 黄色免费成人| 欧美激情福利| 国产精品社区| 中国字幕a在线看韩国电影| 亚洲综合福利| 国产高潮在线| 欧美在线精品一区| 在线成人动漫av| 欧美一区二区三区久久| 香蕉久久精品| 激情久久99| 日韩不卡在线观看日韩不卡视频 | 红桃视频国产精品| 国产成人精品免费视| 亚洲午夜久久| 色老板在线视频一区二区| 国产精品观看| 国产日产精品_国产精品毛片 | 女人天堂亚洲aⅴ在线观看| 久久av免费| 99pao成人国产永久免费视频| 久久免费视频66| 一区二区三区四区在线观看国产日韩| 福利在线免费视频| 国产精品传媒麻豆hd| 天堂成人国产精品一区| 国产精品字幕| 美女在线视频一区| 天海翼精品一区二区三区| 亚洲二区视频| 91一区二区三区四区| 国产丝袜一区| 中文字幕免费一区二区| 欧美 日韩 国产精品免费观看| 欧美一区成人| 免费看欧美美女黄的网站| 好吊视频一区二区三区四区| 久久久9色精品国产一区二区三区| 91中文字幕精品永久在线| 麻豆一区二区三| 国产精品色在线网站| 日本三级亚洲精品| 日韩精品亚洲专区| 蜜桃久久久久久| 日本 国产 欧美色综合| 亚洲ab电影| 日韩在线一区二区| 三上悠亚国产精品一区二区三区 | 美女视频免费精品| 国产亚洲亚洲| 欧美+日本+国产+在线a∨观看| 久久久男人天堂| 久久在线电影| 精品国产亚洲日本| 国产精品毛片久久久| 国产欧美日韩影院| 911精品国产| 国产日韩免费| 欧美日韩精品一区二区三区在线观看| 亚洲在线电影| 美女国产精品| 一区二区国产精品| 日本综合精品一区| 欧美色综合网| 久久国产尿小便嘘嘘| 日本亚洲视频在线| 另类专区亚洲| 日韩一区二区在线免费| 福利在线免费视频| 国产精品99久久精品| 国产一区二区三区视频在线| 国精品产品一区| 国模精品一区| 欧美一区久久久| 国精品产品一区| zzzwww在线看片免费| 人人精品亚洲| 黄色日韩在线| 亚洲精选91| 亚洲一区二区三区四区电影| 精品国产网站| 日韩精品免费一区二区三区| 蜜桃久久av| 国产精品伊人| 午夜欧美视频| 日韩精品五月天| 中文字幕在线高清| 亚洲精品大片| 国产资源在线观看入口av| 日韩精品91亚洲二区在线观看| 精品国产一区二区三区噜噜噜| 久久久精品区| 麻豆精品蜜桃| 午夜在线视频一区二区区别| 日日夜夜免费精品| 国产精品夜夜夜| 中文字幕一区久| 亚洲欧洲一区| 日韩精品电影一区亚洲| 久久精品三级| 亚洲激情另类| 日韩福利在线观看| 高清精品久久| 中日韩男男gay无套| 日本久久一区| 国产不卡人人| 免费观看在线综合| 欧美黑人巨大videos精品| 亚洲成av在线| 视频一区视频二区中文| 国产精品美女久久久久久不卡| 欧美一区久久久| 亚洲精品日韩久久| 黄色欧美在线| 天堂成人国产精品一区| 精品亚洲a∨一区二区三区18| 久久中文字幕av| 日本午夜精品| sm久久捆绑调教精品一区| 亚洲成人精品| 色综合视频一区二区三区日韩| 国产精品黑丝在线播放| 亚洲综合福利| 88xx成人免费观看视频库| 一级成人国产| 国产精品99一区二区三| 免费看黄色91| 国产伦久视频在线观看| 亚洲成人日韩| 亚洲精一区二区三区| 石原莉奈在线亚洲二区| 亚洲视频二区| 日本成人手机在线| 午夜久久99| 岛国av在线网站| 蜜臀久久99精品久久久画质超高清|