集成框架 -- 項目啟動時創建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.pswp.cn/web/14107.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/14107.shtml
英文地址,請注明出處:http://en.pswp.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…