为啥 Spring Batch 在我的 Ubuntu 20.04 机器上的 MySql 上创建小写表?

Posted

技术标签:

【中文标题】为啥 Spring Batch 在我的 Ubuntu 20.04 机器上的 MySql 上创建小写表?【英文标题】:Why Spring Batch is creating lower case table on MySql on my Ubuntu 20.04 machine?为什么 Spring Batch 在我的 Ubuntu 20.04 机器上的 MySql 上创建小写表? 【发布时间】:2021-11-14 10:47:18 【问题描述】:

我正在处理一个 Spring Batch 项目(在 Spring Boot 上运行),我遇到了一个棘手的问题。

到目前为止,我基本上都使用 H2 数据库。为了投入生产(在 Ubuntu 20.04 机器上),我正在尝试用 mysql 替换它。

这是我的 application.properties 初始配置(使用 H2 数据库):

#Database Configuration
spring.datasource.url=jdbc:h2:mem:springbatch;DB_CLOSE_ON_EXIT=FALSE
spring.datasource.username=sa
spring.datasource.password=

所以我用这些新配置替换了这些配置,使用 MySql 而不是 H2:

spring.datasource.platform=mysql
spring.datasource.driverClassName=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/spring
spring.datasource.username=andrea
spring.datasource.password=Aprile_12_Test
spring.datasource.initialization-mode=always

正如您所见,初始化模式设置为 always,因此运行我的 Spring Batch 应用程序,表将被创建到我的 spring MySql 数据库中。表已创建但它们是小写的(进入使用的 schema-mysql.sql 文件都是大写的:

mysql> show tables;
+------------------------------+
| Tables_in_spring             |
+------------------------------+
| BATCH_JOB_EXECUTION          |
| BATCH_JOB_INSTANCE           |
| DATABASECHANGELOG            |
| DATABASECHANGELOGLOCK        |
| batch_job_execution          |
| batch_job_execution_context  |
| batch_job_execution_params   |
| batch_job_instance           |
| batch_step_execution         |
| batch_step_execution_context |
+------------------------------+

这似乎是一些错误的原因,因为它不会使用带有大写引用的表创建其他表。

为什么我会遇到这个问题?我能做些什么来解决这个问题?是否存在指定使用 .sql 文件中定义的大写名称的方法?

【问题讨论】:

使用小写名称使其独立于平台始终是一个好习惯。 Linux 和 Windows 对待它们的方式不同。 【参考方案1】:

我自己解决了允许 Spring Boot\Batch 第一次创建数据库表。进入 application.properties::

spring.datasource.initialization-mode=always

从 pom.xml 中移除 Liquidebase 库:

<!-- 
<dependency>
    <groupId>org.liquibase</groupId>
    <artifactId>liquibase-core</artifactId>
    <scope>runtime</scope>
</dependency>
-->

最后在 application.properties 中禁用数据库表创建:

spring.datasource.initialization-mode=never

最终运行批处理。问题似乎是液基。

【讨论】:

以上是关于为啥 Spring Batch 在我的 Ubuntu 20.04 机器上的 MySql 上创建小写表?的主要内容,如果未能解决你的问题,请参考以下文章

(Spring Batch)为啥表'batch_job_instance'已经存在?

为啥我的 Spring Batch 多线程步骤在任何处理之前执行所有读取?

Spring Batch 在流程中有两个步骤。为啥第二步永远不会运行,第一步是无限循环

Spring Batch JpaItemWriter vs HibernateItemWriter 以及为啥在使用 HibernateItemWriter 时需要 HibernateTransacti

为啥在尝试对整个 Spring Batch Job 进行单元测试时出现此错误?没有可用的“org.springframework.batch.core.Job”类型的合格bean

为啥 Spring Batch 为每个线程使用 1 个数据库连接?