在为企业应用程序开发模块化系统架构时,我遇到了一些数据库初始化问题。我们有一个提供基本实体和基本配置的核心库。在这个核心之上构建了几个模块。它们是可插拔的,可以有自己的实体和配置。一些特点:
- 配置,如系统属性、资源包等,都存储在数据库中。
- JPA 用于使系统数据库独立。
- 系统在 Java SE 上运行
每个模块都可以自带表,但它们也可以要求填充核心属性表或核心资源包表。所以不知何故,我们需要一些机制来为数据库运行 DDL 和 DML 初始化。一些选项:
- 创建简单的 sql 脚本。缺点是它们必须是独立于数据库的,也许这不是对开发人员最友好的。除非我们可以使用一些 DB diff 工具生成它们?
- 使用 Java 类通过 JPQL 进行初始化?
- 将配置存储在文件中?这避免了很多(但不是全部)配置 DML。
- 使用像 liquibase 这样的工具?
这个(或类似的)问题的最佳实践是什么?