如何为 Quartz 调度程序设置 HSQLDB 模式

Posted

技术标签:

【中文标题】如何为 Quartz 调度程序设置 HSQLDB 模式【英文标题】:Howto setup HSQLDB schema for Quartz scheduler 【发布时间】:2013-05-13 22:08:38 【问题描述】:

我正在编写一个“简单”的调度程序应用程序,它使用了出色的 Quartz 调度框架。

Quartz 适用于大多数数据库系统(mysql、Oracle、HSQLDB,...),只需在quartz.properties 配置文件中指定即可。使用的数据库必须使用相应的 SQL 初始化脚本进行初始化,该脚本可以在 Quartz 安装的 docs/dbTables 目录中找到。

使用 MySQL 数据库,我只需要在数据库上运行 tables_mysql.sql 脚本,一切都很好。

现在我打算切换到以文件模式运行的内存数据库 (HSQLDB)。启动我的应用程序似乎可以正确创建 HSQLDB,但现在我找不到在此数据库上运行 init 脚本的简单方法。

检查 Google 和 *** 我找到了一些解决方案,但它们需要 spring-framework、hibernate、Flyway 或以编程方式获取连接并解析/执行 init 脚本中的语句。

我的问题:有没有更简单的方法来为 Quartz 设置 HSQLDB?理想情况下,Quartz 会自行完成,因为它知道其配置文件中的数据库连接数据以及所需的设置脚本......我错过了什么吗?

感谢您对此的任何提示!

【问题讨论】:

【参考方案1】:

您可以使用作为 SqlTool 一部分的 SqlFile。这是一个单独的 jar,sqltool.jar,位于 HSQLDB zip 包中。

这可以与 HSQLDB 以及其他数据库引擎一起使用。

用法在其自己的指南中介绍:

http://hsqldb.org/doc/2.0/util-guide/sqltool-chapt.html

【讨论】:

【参考方案2】:

简单的方法是获取您的石英版本的架构文件(tables_hsqldb.sql)并在 application.properties 文件中提供架构文件的路径,然后 spring 将自行创建架构。否则您可以放置​​架构资源文件夹中的文件。然后您需要将数据源通知给quartz,以便quartz 处理所有事情。

【讨论】:

以上是关于如何为 Quartz 调度程序设置 HSQLDB 模式的主要内容,如果未能解决你的问题,请参考以下文章

HSQLDB 2.3.3:如何为序列返回下一个值的数组

如何使用 Spring Boot 和 Flyway 为 Quartz 调度程序设置数据库模式?

如何为 Google Cloud Scheduler 设置基本身份验证

quartz任务调度框架与spring整合

如何为所有远程登录的用户设置默认进程调度优先级(“nice”值)?

Quartz使用