SlideShare a Scribd company logo
Database migrations
Flyway and Liquibase
Lars Östling
lars.ostling@jayway.com
@larsostling
Agenda
• Database migrations
• Flyway
• Liquibase
• Conclusions
Back in the day…
• Big up-front design
• Long development cycles
• Scary updates
In an agile world…
• Short iterations
• Continuous integration /
delivery / deployment
• Delivery pipe-lines
• We do it for code …
• … what about the database?
Database migrations with Flyway and Liquibase
The challenge
• Frequent database updates
• Managing multiple sql files
• What has been applied and
what has not?
• Keeping code and database
in sync …
• … throughout all
environments
The solution
Automated database migrations:
• Recreate database from
scratch
• Make it clear at all times what
state a database is in
• Migrate in a deterministic way
from current version of the
database to a newer one
Database migrations with Flyway and Liquibase
What is Flyway?
• Agile database migration framework for Java
• Open Source Apache 2.0 license
• Started in 2010
• Status ‘Adopt’ on thoughtworks technology radar
• http://www.flywaydb.org
Demo
https://github.com/larsostling/
database-migrations-demo
Short recap
• Schema version table
• Convention over configuration
• Sql and java migrations
• Supereasy to setup
Database migrations with Flyway and Liquibase
What is Liquibase?
• Agile database migration framework for Java
• Open Source Apache 2.0 license
• Started in 2006
• http://www.liquibase.org
Demo
https://github.com/larsostling/
database-migrations-demo
Short recap
• Uses structured DSL to
describe database changes
• Databasechangelog table
• Supports rollback
• generateChangeLog
Flyway vs. Liquibase
• SQL vs. XML
• Multiple files vs. single file
• No rollback vs. rollback
• KISS vs. less KISS
Some advice
• Migrate on application startup
• Change sets do not change
• People and processes
Lessons learned
• Stop worrying about database
changes
• Pick a framework and start
using it
Q & A
Thanks!
Lars Östling
lars.ostling@jayway.com
@larsostling

More Related Content

What's hot (20)

PPTX
Azure DevOps in Action
Callon Campbell
 
PPTX
Introduction to Maven
Mindfire Solutions
 
PPTX
Docker: From Zero to Hero
fazalraja
 
PPTX
Couchbase 101
Dipti Borkar
 
PPTX
Jenkins tutorial
Mamun Rashid, CCDH
 
PPTX
Intro to Azure DevOps
Lorenzo Barbieri
 
PDF
CI CD Pipeline Using Jenkins | Continuous Integration and Deployment | DevOps...
Edureka!
 
PPTX
Azure storage deep dive
Sergio Navarro Pino
 
PPT
Angular Introduction By Surekha Gadkari
Surekha Gadkari
 
PDF
Service discovery with Eureka and Spring Cloud
Marcelo Serpa
 
PPTX
Devops as a service
Saravanan Subburayal
 
PPTX
Spring Web MVC
zeeshanhanif
 
PPTX
Getting started with agile database migrations for java flywaydb
Girish Bapat
 
PDF
DevOps
ARYA TM
 
PDF
Apache Kafka in the Airline, Aviation and Travel Industry
Kai Wähner
 
PPTX
A brief introduction to IaC with Terraform by Kenton Robbins (codeHarbour May...
Alex Cachia
 
DOCX
Gaganjot Kaur- The Nx Workspace.docx
Gaganjot kaur
 
KEY
Git with bitbucket
Sumin Byeon
 
PPTX
MongoDB Ops Manager
Norberto Leite
 
Azure DevOps in Action
Callon Campbell
 
Introduction to Maven
Mindfire Solutions
 
Docker: From Zero to Hero
fazalraja
 
Couchbase 101
Dipti Borkar
 
Jenkins tutorial
Mamun Rashid, CCDH
 
Intro to Azure DevOps
Lorenzo Barbieri
 
CI CD Pipeline Using Jenkins | Continuous Integration and Deployment | DevOps...
Edureka!
 
Azure storage deep dive
Sergio Navarro Pino
 
Angular Introduction By Surekha Gadkari
Surekha Gadkari
 
Service discovery with Eureka and Spring Cloud
Marcelo Serpa
 
Devops as a service
Saravanan Subburayal
 
Spring Web MVC
zeeshanhanif
 
Getting started with agile database migrations for java flywaydb
Girish Bapat
 
DevOps
ARYA TM
 
Apache Kafka in the Airline, Aviation and Travel Industry
Kai Wähner
 
A brief introduction to IaC with Terraform by Kenton Robbins (codeHarbour May...
Alex Cachia
 
Gaganjot Kaur- The Nx Workspace.docx
Gaganjot kaur
 
Git with bitbucket
Sumin Byeon
 
MongoDB Ops Manager
Norberto Leite
 

Similar to Database migrations with Flyway and Liquibase (20)

PPTX
Delhi_Meetup_flyway_Integration.pptx
AnuragSharma900
 
PDF
Javaone 2014
Rikard Thulin
 
PPTX
Continuous DB Changes Delivery With Liquibase
Aidas Dragūnas
 
ODP
Liquibase & Flyway @ Baltic DevOps
Andrei Solntsev
 
PDF
Database Schema Evolution
Lars Thorup
 
PDF
Delivering Changes for Applications and Databases
Miguel Alho
 
PPT
LiquiBase
Mike Willbanks
 
PPT
Evolutionary Database Design
Andrei Solntsev
 
PDF
Delivering changes for applications and databases
Eduardo Piairo
 
PPTX
Evolutionary database design
Salehein Syed
 
ODP
Handling Database Deployments
Mike Willbanks
 
PPTX
Liquibase Integration with MuleSoft
NeerajKumar1965
 
PDF
Best Practices in Migrating to MySQL - Part 1
Ronald Bradford
 
PPTX
MuleSoft integration with Liquibase | Mysore MuleSoft Meetup #3
MysoreMuleSoftMeetup
 
PDF
Liquibase få kontroll på dina databasförändringar
Squeed
 
PDF
[DevDay2018] Automate database migration using flyway framework - By Karthick...
DevDay Da Nang
 
PPTX
Database versioning with liquibase
Return on Intelligence
 
PPTX
Liquibase
Sergii Fesenko
 
PPTX
Flyway
Rajesh Kumar
 
PPTX
Liquibase case study
Vivek Dhayalan
 
Delhi_Meetup_flyway_Integration.pptx
AnuragSharma900
 
Javaone 2014
Rikard Thulin
 
Continuous DB Changes Delivery With Liquibase
Aidas Dragūnas
 
Liquibase & Flyway @ Baltic DevOps
Andrei Solntsev
 
Database Schema Evolution
Lars Thorup
 
Delivering Changes for Applications and Databases
Miguel Alho
 
LiquiBase
Mike Willbanks
 
Evolutionary Database Design
Andrei Solntsev
 
Delivering changes for applications and databases
Eduardo Piairo
 
Evolutionary database design
Salehein Syed
 
Handling Database Deployments
Mike Willbanks
 
Liquibase Integration with MuleSoft
NeerajKumar1965
 
Best Practices in Migrating to MySQL - Part 1
Ronald Bradford
 
MuleSoft integration with Liquibase | Mysore MuleSoft Meetup #3
MysoreMuleSoftMeetup
 
Liquibase få kontroll på dina databasförändringar
Squeed
 
[DevDay2018] Automate database migration using flyway framework - By Karthick...
DevDay Da Nang
 
Database versioning with liquibase
Return on Intelligence
 
Liquibase
Sergii Fesenko
 
Flyway
Rajesh Kumar
 
Liquibase case study
Vivek Dhayalan
 
Ad

Recently uploaded (20)

PPTX
Homogeneity of Variance Test Options IBM SPSS Statistics Version 31.pptx
Version 1 Analytics
 
PDF
Why Businesses Are Switching to Open Source Alternatives to Crystal Reports.pdf
Varsha Nayak
 
PDF
SAP Firmaya İade ABAB Kodları - ABAB ile yazılmıl hazır kod örneği
Salih Küçük
 
PDF
Revenue streams of the Wazirx clone script.pdf
aaronjeffray
 
PPTX
Tally_Basic_Operations_Presentation.pptx
AditiBansal54083
 
PDF
SciPy 2025 - Packaging a Scientific Python Project
Henry Schreiner
 
PPTX
Agentic Automation Journey Series Day 2 – Prompt Engineering for UiPath Agents
klpathrudu
 
PDF
MiniTool Partition Wizard 12.8 Crack License Key LATEST
hashhshs786
 
PPTX
Transforming Mining & Engineering Operations with Odoo ERP | Streamline Proje...
SatishKumar2651
 
PPTX
Agentic Automation Journey Session 1/5: Context Grounding and Autopilot for E...
klpathrudu
 
PDF
MiniTool Partition Wizard Free Crack + Full Free Download 2025
bashirkhan333g
 
PPTX
Empowering Asian Contributions: The Rise of Regional User Groups in Open Sour...
Shane Coughlan
 
PDF
The 5 Reasons for IT Maintenance - Arna Softech
Arna Softech
 
PDF
Download Canva Pro 2025 PC Crack Full Latest Version
bashirkhan333g
 
PDF
Digger Solo: Semantic search and maps for your local files
seanpedersen96
 
PPTX
Migrating Millions of Users with Debezium, Apache Kafka, and an Acyclic Synch...
MD Sayem Ahmed
 
PDF
AI + DevOps = Smart Automation with devseccops.ai.pdf
Devseccops.ai
 
PPTX
Agentic Automation: Build & Deploy Your First UiPath Agent
klpathrudu
 
PPTX
In From the Cold: Open Source as Part of Mainstream Software Asset Management
Shane Coughlan
 
PDF
Alexander Marshalov - How to use AI Assistants with your Monitoring system Q2...
VictoriaMetrics
 
Homogeneity of Variance Test Options IBM SPSS Statistics Version 31.pptx
Version 1 Analytics
 
Why Businesses Are Switching to Open Source Alternatives to Crystal Reports.pdf
Varsha Nayak
 
SAP Firmaya İade ABAB Kodları - ABAB ile yazılmıl hazır kod örneği
Salih Küçük
 
Revenue streams of the Wazirx clone script.pdf
aaronjeffray
 
Tally_Basic_Operations_Presentation.pptx
AditiBansal54083
 
SciPy 2025 - Packaging a Scientific Python Project
Henry Schreiner
 
Agentic Automation Journey Series Day 2 – Prompt Engineering for UiPath Agents
klpathrudu
 
MiniTool Partition Wizard 12.8 Crack License Key LATEST
hashhshs786
 
Transforming Mining & Engineering Operations with Odoo ERP | Streamline Proje...
SatishKumar2651
 
Agentic Automation Journey Session 1/5: Context Grounding and Autopilot for E...
klpathrudu
 
MiniTool Partition Wizard Free Crack + Full Free Download 2025
bashirkhan333g
 
Empowering Asian Contributions: The Rise of Regional User Groups in Open Sour...
Shane Coughlan
 
The 5 Reasons for IT Maintenance - Arna Softech
Arna Softech
 
Download Canva Pro 2025 PC Crack Full Latest Version
bashirkhan333g
 
Digger Solo: Semantic search and maps for your local files
seanpedersen96
 
Migrating Millions of Users with Debezium, Apache Kafka, and an Acyclic Synch...
MD Sayem Ahmed
 
AI + DevOps = Smart Automation with devseccops.ai.pdf
Devseccops.ai
 
Agentic Automation: Build & Deploy Your First UiPath Agent
klpathrudu
 
In From the Cold: Open Source as Part of Mainstream Software Asset Management
Shane Coughlan
 
Alexander Marshalov - How to use AI Assistants with your Monitoring system Q2...
VictoriaMetrics
 
Ad

Database migrations with Flyway and Liquibase