...
- CI continuously monitors the 3 system of record locations
- As soon as a change is detected, a job is fired to generate SQL from the system of record locations
- The job generates SQL for MySQL and Oracle
- Any new or altered SQL is checked into its corresponding generated location
- Any old SQL is removed from its corresponding location
- This assures the GENERATED locations are automatically kept in sync with the SYSTEM OF RECORD locations as changes are committed
- The CI job also creates metadata describing the SQL files for each location -
src/main/resources/META-INF
- As soon as SQL generation completes, a CI job is fired to execute the SQL
- The SQL execution job executes the SQL for both MySQL and Oracle against test databases
- The SQL execution job is a lightweight Spring based component at its core
- The Spring based nature of the SQL execution decouples the database creation process from:
- The file system
- The build system
- Source code management system
- "Other" random requirements imposed by the tooling being used to convert database agnostic XML into database specific SQL
- XML Impex
- Hard coded relative pathing issues between the java code being executed and the velocity templates
- Overall size limitation
- CloverETL Impex
- No ability to declaratively express a dependency on a published version of the tool
- Hard coded path related to workspace.prm requiring the java virtual machine to be launched from the same directory as the tool itself
- Liquibase
- Requires a connection to a live database containing the tables
DATABASECHANGELOG
andDATABASECHANGELOGLOCK
even if all you are doing is generating SQL from XML
- Requires a connection to a live database containing the tables
- XML Impex
- The Spring based execution of the SQL happens to run faster, but improving execution speed is not the point
- Decoupling the database creation process from file systems, build systems, source code managements systems, and tools that also require those things is the point