电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:95日期: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
相關文章:
主站蜘蛛池模板: 自动气象站_农业气象站_超声波气象站_防爆气象站-山东万象环境科技有限公司 | 天津拓展_天津团建_天津趣味运动会_天津活动策划公司-天津华天拓展培训中心 | 热镀锌槽钢|角钢|工字钢|圆钢|H型钢|扁钢|花纹板-天津千百顺钢铁贸易有限公司 | 胀套-锁紧盘-风电锁紧盘-蛇形联轴器「厂家」-瑞安市宝德隆机械配件有限公司 | 北京征地律师,征地拆迁律师,专业拆迁律师,北京拆迁律师,征地纠纷律师,征地诉讼律师,征地拆迁补偿,拆迁律师 - 北京凯诺律师事务所 | CPSE安博会| 水平筛厂家-三轴椭圆水平振动筛-泥沙震动筛设备_山东奥凯诺矿机 包装设计公司,产品包装设计|包装制作,包装盒定制厂家-汇包装【官方网站】 | 特材真空腔体_哈氏合金/镍基合金/纯镍腔体-无锡国德机械制造有限公司 | 在线浊度仪_悬浮物污泥浓度计_超声波泥位计_污泥界面仪_泥水界面仪-无锡蓝拓仪表科技有限公司 | 软文推广发布平台_新闻稿件自助发布_媒体邀约-澜媒宝 | 量子管通环-自清洗过滤器-全自动反冲洗过滤器-沼河浸过滤器 | 智能家居全屋智能系统多少钱一套-小米全套价格、装修方案 | 高效节能电机_伺服主轴电机_铜转子电机_交流感应伺服电机_图片_型号_江苏智马科技有限公司 | 杭州顺源过滤机械有限公司官网-压滤机_板框压滤机_厢式隔膜压滤机厂家 | 一点车讯-汽车网站,每天一点最新车讯! | 电缆桥架生产厂家_槽式/梯式_热镀锌线槽_广东东莞雷正电气 | 大型多片锯,圆木多片锯,方木多片锯,板材多片锯-祥富机械有限公司 | 企典软件一站式企业管理平台,可私有、本地化部署!在线CRM客户关系管理系统|移动办公OA管理系统|HR人事管理系统|人力 | 聚氨酯保温钢管_聚氨酯直埋保温管道_聚氨酯发泡保温管厂家-沧州万荣防腐保温管道有限公司 | 越南专线物流_东莞国际物流_东南亚专线物流_行通物流 | 真空吸污车_高压清洗车厂家-程力专用汽车股份有限公司官网 | 知企服务-企业综合服务(ZiKeys.com)-品优低价、种类齐全、过程管理透明、速度快捷高效、放心服务,知企专家! | Copeland/谷轮压缩机,谷轮半封闭压缩机,谷轮涡旋压缩机,型号规格,技术参数,尺寸图片,价格经销商 CTP磁天平|小电容测量仪|阴阳极极化_双液系沸点测定仪|dsj电渗实验装置-南京桑力电子设备厂 | 波纹补偿器_不锈钢波纹补偿器_巩义市润达管道设备制造有限公司 | pbt头梳丝_牙刷丝_尼龙毛刷丝_PP塑料纤维合成毛丝定制厂_广州明旺 | 自动气象站_农业气象站_超声波气象站_防爆气象站-山东万象环境科技有限公司 | 液压油缸-液压站生产厂家-洛阳泰诺液压科技有限公司 | 水冷式工业冷水机组_风冷式工业冷水机_水冷螺杆冷冻机组-深圳市普威机械设备有限公司 | 知网论文检测系统入口_论文查重免费查重_中国知网论文查询_学术不端检测系统 | 西安耀程造价培训机构_工程预算实训_广联达实作实操培训 | 移动机器人产业联盟官网| 儿童乐园|游乐场|淘气堡招商加盟|室内儿童游乐园配套设备|生产厂家|开心哈乐儿童乐园 | 细砂提取机,隔膜板框泥浆污泥压滤机,螺旋洗砂机设备,轮式洗砂机械,机制砂,圆锥颚式反击式破碎机,振动筛,滚筒筛,喂料机- 上海重睿环保设备有限公司 | 2025黄道吉日查询、吉时查询、老黄历查询平台- 黄道吉日查询网 | 焊缝跟踪系统_激光位移传感器_激光焊缝跟踪传感器-创想智控 | 短信营销平台_短信群发平台_106短信发送平台-河南路尚 | 散热器-电子散热器-型材散热器-电源散热片-镇江新区宏图电子散热片厂家 | 青岛代理记账_青岛李沧代理记账公司_青岛崂山代理记账一个月多少钱_青岛德辉财税事务所官网 | 精密机械零件加工_CNC加工_精密加工_数控车床加工_精密机械加工_机械零部件加工厂 | 干式变压器厂_干式变压器厂家_scb11/scb13/scb10/scb14/scb18干式变压器生产厂家-山东科锐变压器有限公司 | 气力输送_输送机械_自动化配料系统_负压吸送_制造主力军江苏高达智能装备有限公司! |