A simple Gradle and Java project that builds a database schema using Flyway.
This codebase defines an example SQL schema, an example Java program that connects to the database (Postgres), and uses Flyway to apply the schema to the database via a so-called database migration. Flyway is invoked by way of the Flyway Gradle plugin.
Follow these instructions to perform a database migration and run the sample program.
- Use Java 17
- Start the database
-
docker-compose up --detach
-
- Run the database migration
-
./gradlew flywayMigrate --info
- The database tables and sample data were created!
- Tons of stuff was logged to the screen unfortunately, but if you look closely you'll see something like:
...omitted... Creating Schema History table "public"."flyway_schema_history" ... Migrating schema "public" to version "1 - observations-schema" Migrating schema "public" to version "2 - observations-data" Successfully applied 2 migrations to schema "public", now at version v2 (execution time 00:00.176s) ...omitted...
-
- Run the Java program
-
./gradlew run
- Notice that the program successfully read from the table!
-
- Stop the database
-
docker-compose down
-