Flyway in an extremely convenient database migraton tool.
First and foremost it integrates wonderfully with maven.
But one of its biggest assets is the ability to run both sql migration scripts and java migration scripts.
Let us start with a simple maven project
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>migration</groupId> <artifactId>com.gkatzioura</artifactId> <version>1.0-SNAPSHOT</version> <properties> <flyway.version>3.1</flyway.version> <mysql.driver.version>5.1.33</mysql.driver.version> <database.url>{your jdbc url}</database.url> <database.user>{your database user}</database.user> <databese.password>{your database password}</databese.password> </properties> <dependencies> <dependency> <groupId>org.flywaydb</groupId> <artifactId>flyway-core</artifactId> <version>${flyway.version}</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.flywaydb</groupId> <artifactId>flyway-maven-plugin</artifactId> <version>${flyway.version}</version> <configuration> <baselineOnMigrate>true</baselineOnMigrate> <url>${database.url}</url> <user>${database.user}</user> <password>${databese.password}</password> </configuration> <dependencies> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>${mysql.driver.version}</version> </dependency> </dependencies> </plugin> </plugins> </build> </project>
When you issue through maven
mvn flyway:migrate
Then flyway will will lookup on the db/migration folder of your target to find any migration files. This folder can be changed by altering the content of the locations inside the configuration of the flyway plugin.
For my first migration file I will use sql
The sql file will be located on the db/migration folder which will reside on the maven resources folder.
The name would be V1_1__Create_Persons.sql
Therefore the full path would be src/main/resources/db/migration/V1_1__Create_Persons.sql
CREATE TABLE Persons ( PersonID bigint(20) NOT NULL AUTO_INCREMENT, LastName varchar(255), FirstName varchar(255), );
The second file would be a java file.
It will be located on the package db.migration folder which will reside on the maven src folder.
The name would be V1_2__Insert_Persons.java
Therefore the full path would be src/main/java/db/migration/V1_2__Insert_Persons.java
package db.migration; import org.flywaydb.core.api.migration.jdbc.JdbcMigration; import java.sql.Connection; import java.sql.Statement; public class V1_2__Insert_Persons implements JdbcMigration { @Override public void migrate(Connection connection) throws Exception { Statement stmt = connection.createStatement(); stmt.addBatch("INSERT INTO Persons (FirstName,LastName) VALUES ('Emmanouil','Gkatziouras')"); stmt.addBatch("INSERT INTO Persons (FirstName,LastName) VALUES ('Do not know','this guy')"); try { stmt.executeBatch(); } finally { stmt.close(); } } }
Since we provide a java file it is wise to call flyway by
mvn clean compile flyway:migrate
2 thoughts on “Database migration with Flyway”