当前位置: 首页 > news >正文

Spring Boot,在应用程序启动后执行某些 SQL 语句

在 Spring Boot 中,如果你想在应用程序启动后执行某些 SQL 语句,可以利用 spring.sql.init 属性来配置初始化脚本。这通常用于在应用启动时创建数据库表、索引、视图等,或者填充默认数据。

data-locationsschema-locations 指定了 SQL 脚本的位置。这些脚本应该位于类路径中指定的目录下。例如:

  • src/main/resources/db/schema.sql 用于创建数据库结构。
  • src/main/resources/db/data.sql 用于插入初始数据

schema.sql 中,你可以编写用于创建表的 SQL 语句

-- schema.sql 文件内容
CREATE TABLE IF NOT EXISTS users (id INT AUTO_INCREMENT,name VARCHAR(100),email VARCHAR(150),PRIMARY KEY (id)
);

data.sql 中,你可以插入一些初始数据

-- data.sql 文件内容
INSERT INTO users (name, email) VALUES ('Alice', 'alice@example.com');
INSERT INTO users (name, email) VALUES ('Bob', 'bob@example.com');

核心文件yml文件修改

spring:application:name: demo_1datasource:url: jdbc:mysql://127.0.0.1:3306/shanshui?useUnicode=true&characterEncoding=utf-8&serverTimezoneusername: rootpassword: 123456driver-class-name: com.mysql.cj.jdbc.Driversql:init:# 数据库 ddl 脚本位置schema-locations: classpath:db/schema.sql# 数据库 dml 脚本位置data-locations: classpath:db/data.sql# always:应用每次启动都执行,never:禁用mode: always


http://www.mrgr.cn/news/27747.html

相关文章:

  • 【idea】更换快捷键
  • 进程信号
  • 游戏引擎学习第10天
  • python os.path.dirname(path) 详解
  • 五、函数封装及调用、参数及返回值、作用域、匿名函数、立即执行函数
  • vue3 组件通信 --- useAttrs()
  • QT模型视图结构1
  • 链式二叉树的基本操作(C语言版)
  • 【自动化测试】自动化测试的价值和误区以及如何高效实用地落地自动化测试
  • 2024/9/15 408“回头看”之应用层小总结(下)
  • QT开发:C++ Qt 信号与槽机制概括性总结
  • 福建科立讯通信 指挥调度管理平台 SQL注入漏洞
  • Ruoyi Cloud K8s 部署
  • 危机中的机遇:客户服务在品牌危机管理中的角色与价值
  • 【Git】常见命令(仅笔记)
  • [使用Zep云存储优化AI助手的记忆功能,提升效率!]
  • vscode
  • TypeScript 快速上⼿ (3:装饰器)
  • Git项目管理工具
  • 物联网之Arduino编程语言
  • Windows本地制作java证书(与jeecgboot配置本地证书ssl问题)
  • 【Python】基本使用
  • YOLO学习笔记 | YOLO目标检测算法(YOLO-V2)
  • ModuleNotFoundError: No module named ‘datasets‘
  • 各大搜索引擎提交入口
  • 209.长度最小的子数组(滑动窗口类)