集成框架 -- 项目启动时创建mysql数据库结构

使用 Spring JDBC DataSource 初始化

  • 前言
  • 正文
    • 配置Spring JDBC的DataSource初始化
      • application.properties
      • application.yml
    • 使用 data.sql 进行数据库初始化
      • application.properties
      • application.yml
      • application.properties
      • application.yml

前言

项目中要使用一些数据库,默认数据。所以需要做一些初始化操作

正文

配置Spring JDBC的DataSource初始化

如果您要执行自定义路径下的SQL文件,可以通过配置Spring JDBC的DataSource初始化去执行特定路径下的SQL文件:


@Configuration
public class DataSourceConfig {@Beanpublic DataSourceInitializer dataSourceInitializer(DataSource dataSource) {DataSourceInitializer initializer = new DataSourceInitializer();initializer.setDataSource(dataSource);initializer.setDatabasePopulator(databasePopulator());return initializer;}private DatabasePopulator databasePopulator() {ResourceDatabasePopulator populator = new ResourceDatabasePopulator();populator.addScript(new ClassPathResource("database/xxxx.sql"));return populator;}
}

确保将reformer.sql文件放至src/main/resources/database/目录下。

application.properties

spring.datasource.schema=classpath*:database/xxxx.sql

application.yml

spring:datasource:schema: classpath*:database/xxxx.sql

这告诉Spring Boot去执行启动时指定的SQL脚本。

使用 data.sql 进行数据库初始化

使用 data.sql 进行数据库初始化,找到资源文件夹 src/main/resources/。在该文件夹内创建一个名为 data.sql 的新文件。

vim src/main/resources/data.sql
INSERT INTO my_table (id, name, description) VALUES (1, 'Name 1', 'Description 1');
INSERT INTO my_table (id, name, description) VALUES (2, 'Name 2', 'Description 2');

application.properties

spring.datasource.initialization-mode=always

application.yml

spring:datasource:initialization-mode: always

确保没有使用JPA的DDL Auto功能,如果您使用了Spring Data JPA,那么可能会有一个 ddl-auto 设置,它可以影响数据库的初始化。默认当使用内嵌数据库时,ddl-auto 设置为 create-drop.

但对于非内嵌数据库,默认为 none。所以,如果您需要Spring Boot执行 data.sql

application.properties


spring.jpa.hibernate.ddl-auto=none

或者:

application.yml

spring:jpa:hibernate:ddl-auto: none

上述配置表示不使用Hibernate的DDL自动生成特性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/14107.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

xjoi题库一级二段题解(c语言版)

开根号 时间:0.2 空间:32M 题目描述: 输入一个整数, 求它的平方根,输出答案向下取整. 比如5√2, 16−−√4 输入格式: 输入一个整数 输出格式: 输出一个整数 样例输入1: 5 样例输出1: 2 样例输…

cn.hutool.poi.excel 实现excel导出效果 首行高度,行样式,颜色,合并单元格,例子样式

需求 接了需求,下载excel模版,本来看着还是简单的,然后实现起来一把泪,首先是使用poi,我查了好久,才实现,然后是我用easyexcel又实现了一遍,用了一个周多才实现。 这是需求&#x…

Python使用virtualenv创建虚拟环境

目录 第一步:安装virtualenv 第二步:选择一个文件夹用来放所创建的虚拟环境 第三步:创建虚拟环境 第四步:激活虚拟环境 第五步:退出虚拟环境 第六步:测试安装django 前提:你得有个python环…

【STL专题】深入探索C++之std::string:不止于字符串【万字详解】

欢迎来到CILMY23的博客 🏆本篇主题为:深入探索C之std::string:不止于字符串 🏆个人主页:CILMY23-CSDN博客 🏆系列专栏:Python | C | C语言 | 数据结构与算法 | 贪心算法 | Linux &#x1f3…

IOS手机自动化一些工具的简单有哪些?

iOS手机自动化测试或操作可以通过多种工具来实现,这些工具提供了丰富的功能,可以帮助开发者和测试人员提高效率。以下是一些简单的iOS自动化工具: 1. Xcode: 苹果官方提供的开发工具,包含了iOS应用开发、调试和自动化测试的功能。…

aardio - godking.vlistEx虚表点击表头全选、排序

新版虚表内置了名称为 DefaultCheckedImg 和 DefaultUnCheckedImg 的两张图片,分别为 【选择框勾选状态默认图片】 和 【选择框未勾选状态默认图片】 以下代码调用了这两张图片,所以请将虚表库升级为最新版。 如果使用旧版库,可以自行添加这…

【Python自动化测试】:Unittest单元测试与HTMLTestRunner自动生成测试用例的好帮手

读者大大们好呀!!!☀️☀️☀️ 🔥 欢迎来到我的博客 👀期待大大的关注哦❗️❗️❗️ 🚀欢迎收看我的主页文章➡️寻至善的主页 文章目录 🔥前言🚀unittest编写测试用例🚀unittest测…

六种常用设计模式

单例设计模式 单例模式指在整个系统生命周期里,保证一个类只能产生一个实例,确保该类的唯一性。 单例模式分类 单例模式可以分为懒汉式和饿汉式,两者之间的区别在于创建实例的时间不同: 懒汉式:指系统运行中&#…

SpringBootWeb 篇-深入了解 Mybatis 删除、新增、更新、查询的基础操作与 SQL 预编译解决 SQL 注入问题

🔥博客主页: 【小扳_-CSDN博客】 ❤感谢大家点赞👍收藏⭐评论✍ 文章目录 1.0 Mybatis 的基础操作 2.0 基础操作 - 环境准备 3.0 基础操作 - 删除操作 3.1 SQL 预编译 3.2 SQL 预编译的优势 3.3 参数占位符 4.0 基础操作 - 新增 4.1 主键返回…

Python图像处理:从基础到高级的全方位指南

目录 第一部分:Python图像处理基础 1.1 图像处理概念 1.2 Python图像处理常用库 1.3 实战案例:图像显示与保存 1.4 注意事项 第二部分:Python图像处理高级技巧 2.1 图像变换 2.2 图像增强 2.3 图像复原 第三部分:Python…

esp32s3中ap与sta模式的wps配对问题

无线路由器中的WPS是Wi-Fi Protected Setup的简称,中文翻译为Wi-Fi安全防护设置,它是由Wi-Fi安全联盟推出的一种无线加密认证方式。主要是为了简化无线局域网的安装及安全性能配置工作,通过这种设置,让无线连接更加方便和安全。省…

20232802 黄千里 2023-2024-2 《网络攻防实践》实践十一报告

20232802 2023-2024-2 《网络攻防实践》实践十一报告 1.实践过程 1.1web浏览器渗透攻击 攻击机:kali172.20.10.10靶机:win2k172.20.10.3 首先在kali中启动msfconsole 输入命令search MS06-014,搜索渗透攻击模块 输入use exploit/window…

终于让我找到了,你也可以学会的人工智能-机器学习教程

给大家分享一套非常棒的python机器学习课程——《AI小天才:让小学生轻松掌握机器学习》,2024年5月完结新课,提供配套的代码笔记软件包下载!学完本课程,可以轻松掌握机器学习的全面应用,复杂特征工程&#x…

C# 跨线程访问UI组件,serialPort1串口接收数据

在Windows应用程序(例如WinForms或WPF)中,UI组件(如按钮、文本框等)都在主线程(也称为UI线程)上运行。当你在一个非UI线程(例如,一个后台线程或者网络请求线程&#xff0…

关于新配置的adb,设备管理器找不到此设备问题

上面页面中一开始没有找到此android设备, 可能是因为我重新配置的adb和设备驱动, 只把adb配置了环境变量,驱动没有更新到电脑中, 点击添加驱动, 选择路径,我安装时都放在了SDK下面,可以尝试…

SpringBoot 实现 RAS+AES 自动接口解密

一、讲个事故 接口安全老生常谈了 过年之前做了过一款飞机大战的H5小游戏,里面无限模式-需要保存用户的积分,因为使用的Body传参,参数是可见的。 为了接口安全我,我和前端约定了传递参数是:用户无限模式的积分“我们…

HTML静态网页成品作业(HTML+CSS)——魅族商城首页网页(1个页面)

🎉不定期分享源码,关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 🏷️本套采用HTMLCSS,未使用Javacsript代码,共有1个页面。 二、作品演示 三、代…

基于Python+OpenCV卷积神经网络的字符识别

欢迎大家点赞、收藏、关注、评论啦 ,由于篇幅有限,只展示了部分核心代码。 文章目录 一项目简介 二、功能三、系统四. 总结 一项目简介 一、项目背景与意义 字符识别是计算机视觉和模式识别领域的一个重要应用,它在文档数字化、车牌识别、验…

gpt-4o考场安排

说明 :经过多次交互,前后花了几个小时,总算完成了基本功能。如果做到按不同层次分配考场,一键出打印结果就完美了。如果不想看中间“艰苦”的过程,请直接跳到“最后结果”及“食用方法”。中间过程还省略了一部分交互&…

Android-多个tv_item_[i] 点击事件简写

private TextView[] tvConstellations new TextView[12];//获取当前id元素并在其点击的时候修改其颜色 for (int i 0; i < 12; i) {int resId getResources().getIdentifier("tv_constellation_" (i1), "id", getPackageName());tvConstellations[i…