Springboot学习(十六) springboot启动使用ScriptRunner执行SQL脚本

  1. 定义监听并执行(其中schema_data.sql放入resources下)
@Slf4j
public class MyApplicationStartedListener implements ApplicationListener<ApplicationStartedEvent> {
    @Override
    public void onApplicationEvent(ApplicationStartedEvent event) {
        ConfigurableApplicationContext applicationContext = event.getApplicationContext();
        DataSource dataSource = applicationContext.getBean(DataSource.class);
        Connection connection = null;
        try {
            connection = dataSource.getConnection();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        ScriptRunner runner=new ScriptRunner(connection);
        try {
            Reader resourceAsReader = Resources.getResourceAsReader("schema_data.sql");
            runner.runScript(resourceAsReader);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}
  1. 添加监听
public class BizApp extends SpringBootServletInitializer {
    public static void main(String[] args) {
        SpringApplication springApplication = new SpringApplication(BizApp.class);
        springApplication.addListeners(new MyApplicationStartedListener());
        springApplication.run(args);
    }
    /**
     *重写configure
     * @param builder
     * @return
     */
    @Override
    protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
        builder.application().addListeners(new MyApplicationStartedListener());
        return builder.sources(BizApp.class);
    }

}

上一篇 配置XSS过滤器
下一篇 springboot下将静态资源路径设置到磁盘的基本目录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值