HAPI FHIR JPA is a constantly evolving product, with new features being added to each new version of the library. As a result, it is generally necessary to execute a database migration as a part of an upgrade to HAPI FHIR.
When upgrading the JPA server from one version of HAPI FHIR to a newer version, often there will be changes to the database schema. The Migrate Database command can be used to perform a migration from one version to the next.
Note that this feature was added in HAPI FHIR 3.5.0. It is not able to migrate from versions prior to HAPI FHIR 3.4.0. Please make a backup of your database before running this command!
The following example shows how to use the migrator utility to migrate to the latest version.
./hapi-fhir-cli migrate-database -d H2_EMBEDDED -u "jdbc:h2:directory:target/jpaserver_h2_files;create=true" -n "" -p ""
You may use the following command to get detailed help on the options:
./hapi-fhir-cli help migrate-database
Note the arguments:
-d [dialect]
– This indicates the database dialect to use. See the detailed help for a list of options.--enable-heavyweight-migrations
– If this flag is set, additional migration tasks will be executed that are considered unnecessary to execute on a database with a significant amount of data loaded. This option is not generally necessary.If you are using Database Partition Mode, add the flag --flags database-partition-mode
to your command.
With this flag added to the command line, the migrator will initialize an empty database with a schema suitable for Database Partition Mode, and will appropriately migrate an existing schema that was initialized with Database Partition Mode. This flag should not be used when migrating an existing schema that was not initially created in Database Partition Mode. It can not be used to convert an existing schema into one that is suitable for this new mode.
For example:
./hapi-fhir-cli migrate-database --flags database-partition-mode -d POSTGRES_9_4 -u "[url]" -n "[username]" -p "[password]"
Note that the Oracle JDBC drivers are not distributed in the Maven Central repository, so they are not included in HAPI FHIR. In order to use this command with an Oracle database, you will need to invoke the CLI as follows:
./hapi-fhir-cli migrate-database -d ORACLE_12C -u "[url]" -n "[username]" -p "[password]"
Some versions of Oracle and Sql Server (e.g. Oracle Standard or Sql Server Standard) do NOT support adding or removing an index without locking the underlying table. If you run migrations while these systems are running, they will have unavoidable long pauses in activity during these changes.
As of HAPI FHIR 3.5.0 a new mechanism for creating the JPA index tables (HFJ_SPIDX_xxx) has been implemented. This new mechanism uses hashes in place of large multi-column indexes. This improves both lookup times as well as required storage space. This change also paves the way for future ability to provide efficient multi-tenant searches (which is not yet implemented but is planned as an incremental improvement).
This change is not a lightweight change however, as it requires a rebuild of the index tables in order to generate the hashes. This can take a long time on databases that already have a large amount of data.
As a result, in HAPI FHIR JPA 3.6.0, an efficient way of upgrading existing databases was added. Under this new scheme, columns for the hashes are added but values are not calculated initially, database indexes are not modified on the HFJ_SPIDX_xxx tables, and the previous columns are still used for searching as was the case in HAPI FHIR JPA 3.4.0.
In order to perform a migration using this functionality, the following steps should be followed:
JpaStorageSettings
to specify that hash-based searches should not be used, using the following setting: myStorageSettings.setDisableHashBasedSearches(true);
extraProperties.put("hibernate.hbm2ddl.auto", "none");
-x no-migrate-350-hashes
on the command line. For example:./hapi-fhir-cli migrate-database -d H2_EMBEDDED -u "jdbc:h2:directory:target/jpaserver_h2_files;create=true" -n "" -p "" -x no-migrate-350-hashes
POST /$mark-all-resources-for-reindexing
. Note that this is a custom operation built into the HAPI FHIR JPA server. It should be secured in a real deployment, so Authentication is likely required for this call.SELECT * FROM HFJ_RES_REINDEX_JOB
JpaStorageSettings
to specify that hash-based searches are used, using the following setting (this is the default setting, so it could also simply be omitted): myStorageSettings.setDisableHashBasedSearches(false);
./hapi-fhir-cli migrate-database -d H2_EMBEDDED -u "jdbc:h2:directory:target/jpaserver_h2_files;create=true" -n "" -p ""
As of version 4.2.0, HAPI FHIR JPA now uses Flyway for schema migrations. The "from" and "to" parameters are no longer used. Flyway maintains a list of completed migrations in a table called FLY_HFJ_MIGRATION
. When you run the migration command, flyway scans the list of completed migrations in this table and compares them to the list of known migrations, and runs only the new ones.
As of version 6.2.0, HAPI FHIR JPA no longer relies on Flyway for schema migrations. HAPI FHIR still maintains a list of completed migrations in a table called FLY_HFJ_MIGRATION
. When you run the migration command, HAPI FHIR scans the list of completed migrations in this table and compares them to the list of known migrations and executes only the new ones.