SpringBoot1.5x与2.0x在使用schema-*.sql自动建表方面的不同

本文对比了SpringBoot1.5x与2.0x在自动建表方面的不同。1.5x版本只需放置schema-*.sql文件即可,而2.0x版本需在application.yml中指定路径并设置initialization-mode:always。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在学习SpringBoot,学习过程中发现了一些1.5x版本与2.0x版本之间小差别,本文主要讲自动建表方面的差别。

1、SpringBoot 1.5x时用法

       方法(1):

                直接在resources文件夹(即类路径)下,新建文件名为schema-*.sql的建表语句脚本文件,启动主应用的时候就会在配置好目标数据库中创建表。

 

  

       方法(2):

                  在application.yml全局配置文件中指定脚本文件的路径,文件名可以任意取,不必带schema前缀,比如:

 

 

 

 2、SpringBoot 2.0x时用法

         在使用springBoot2.0及其以上版本时,我们自动创建表使用1.5x中的方法(1)(即在application.yml文件中不指定脚本路径,只使用schema-*.sql)是不行的,启动主应用不会帮我们自动创建表。

         我们除了需要在application.yml文件中指定脚本路径外,还需要特别注意一点:在application.yml配置文件中加上  initialization-mode: always 这句话。这样SpringBoot在启动时,才能检测到这个配置,之后再检测schema配置的脚本路径,然后去执行脚本文件。

 

                                  

 这样写,就能在数据库中正常创建表了。

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值