Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Aprenda Database Migrations | Working with Databases
Spring Boot Backend

bookDatabase Migrations

This image shows the progression of database migrations across versions. Each version reflects changes to the database structure, such as creating tables, modifying fields, or adding/removing columns, to keep up with application requirements.

When developing an application, you may need to modify the database schema: add new tables, update existing ones, introduce indexes, and so on.

Migrations help manage these changes in a sequential and organized way, ensuring data integrity and keeping the database schema aligned with the application's code. For migrations, we will be using Flyway.

What is Flyway?

One of the key features of Flyway is its support for migration versioning, allowing you to track changes to the database structure and roll back to previous versions if needed.

Creating a Migration With Flyway

To start, add the Flyway dependency to your Spring Boot project. Since we are using Maven, add the following dependency to your pom.xml file:

We will also add another JPA dependency, which works together with Flyway. We will cover JPA in more detail later.

This dependency will help us integrate Flyway into our project! But that's not all, we still need to configure it!

Of course, Flyway needs to know which database it will be working with, so we need to explicitly specify the database and provide access credentials.

The main configurations can be set in application.properties:

spring.flyway.url=jdbc:mysql://localhost:3306/my_database
spring.flyway.user=root
spring.flyway.password={your_password}

We need to specify the url, user, and password to allow Flyway to work with our database.

However, to avoid entering these values multiple times, we can reference them from other parameters using the ${} syntax.

spring.flyway.url=${spring.datasource.url}
spring.flyway.user=${spring.datasource.username}
spring.flyway.password=${spring.datasource.password}

spring.datasource.url=jdbc:mysql://localhost:3306/my_database
spring.datasource.username=root
spring.datasource.password={your_password}
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

In the previous chapter, we created a my_database database and added a book table to it. However, we can now delete the book table since it will be created through a migration.

Now everything is ready for us to create our first migration in the application! We need to create a db folder inside the resources directory, and within that folder, create another one named migration. The full path should look like this: src/main/resources/db/migration.

In the migration directory, we can now create files where we will define our changes. The file format should be V<version>__<description>.sql.

V1__create_table_books.sql

Migrations are applied in the order of their versions. The version numbering must be sequential and without gaps. For example, if you have migrations V1__init.sql and V2__add_column.sql, the next migration should be V3__another_change.sql.

Within the migration file, you can write SQL scripts to define the structure of the database, create new tables, columns, etc.

Let's write the script for creating the books table, which we manually created in the previous chapter, in our V1__create_table_books.sql file.

create table book
(
    id varchar(255) not null primary key,
    name varchar(255) not null,
    author varchar(255) null,
    price decimal(10, 2) null
);

You can also add a parameter to the application.properties file that specifies where the migrations are located, so Flyway knows the exact path to the migration files:

spring.flyway.locations=classpath:db.migration

After this, run the application, and you should see the table created with the fields you specified in the migration!

You can no longer modify the first version of the migration. For each change to your table, you will need to create a new migration file and add the new script there!

Why are Migrations Important?

Migrations are necessary for orderly management of changes in the database, preserving history and allowing for rollbacks when needed.

They help synchronize the database structure across different environments such as development, testing, and production, while also automating the update process, reducing the risk of errors, and ensuring that the database schema remains consistent with the application code.

Each migration also documents specific changes, making it easier to understand and maintain the database schema.

Summary

Using Flyway simplifies and automates the process of managing database changes, leading to more reliable and efficient application development.

1. What is a database migration?

2. What role do migration versions play?

question mark

What is a database migration?

Select the correct answer

question mark

What role do migration versions play?

Select the correct answer

Tudo estava claro?

Como podemos melhorá-lo?

Obrigado pelo seu feedback!

Seção 4. Capítulo 3

Pergunte à IA

expand

Pergunte à IA

ChatGPT

Pergunte o que quiser ou experimente uma das perguntas sugeridas para iniciar nosso bate-papo

Suggested prompts:

Pergunte-me perguntas sobre este assunto

Resumir este capítulo

Mostrar exemplos do mundo real

Awesome!

Completion rate improved to 3.45

bookDatabase Migrations

Deslize para mostrar o menu

This image shows the progression of database migrations across versions. Each version reflects changes to the database structure, such as creating tables, modifying fields, or adding/removing columns, to keep up with application requirements.

When developing an application, you may need to modify the database schema: add new tables, update existing ones, introduce indexes, and so on.

Migrations help manage these changes in a sequential and organized way, ensuring data integrity and keeping the database schema aligned with the application's code. For migrations, we will be using Flyway.

What is Flyway?

One of the key features of Flyway is its support for migration versioning, allowing you to track changes to the database structure and roll back to previous versions if needed.

Creating a Migration With Flyway

To start, add the Flyway dependency to your Spring Boot project. Since we are using Maven, add the following dependency to your pom.xml file:

We will also add another JPA dependency, which works together with Flyway. We will cover JPA in more detail later.

This dependency will help us integrate Flyway into our project! But that's not all, we still need to configure it!

Of course, Flyway needs to know which database it will be working with, so we need to explicitly specify the database and provide access credentials.

The main configurations can be set in application.properties:

spring.flyway.url=jdbc:mysql://localhost:3306/my_database
spring.flyway.user=root
spring.flyway.password={your_password}

We need to specify the url, user, and password to allow Flyway to work with our database.

However, to avoid entering these values multiple times, we can reference them from other parameters using the ${} syntax.

spring.flyway.url=${spring.datasource.url}
spring.flyway.user=${spring.datasource.username}
spring.flyway.password=${spring.datasource.password}

spring.datasource.url=jdbc:mysql://localhost:3306/my_database
spring.datasource.username=root
spring.datasource.password={your_password}
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

In the previous chapter, we created a my_database database and added a book table to it. However, we can now delete the book table since it will be created through a migration.

Now everything is ready for us to create our first migration in the application! We need to create a db folder inside the resources directory, and within that folder, create another one named migration. The full path should look like this: src/main/resources/db/migration.

In the migration directory, we can now create files where we will define our changes. The file format should be V<version>__<description>.sql.

V1__create_table_books.sql

Migrations are applied in the order of their versions. The version numbering must be sequential and without gaps. For example, if you have migrations V1__init.sql and V2__add_column.sql, the next migration should be V3__another_change.sql.

Within the migration file, you can write SQL scripts to define the structure of the database, create new tables, columns, etc.

Let's write the script for creating the books table, which we manually created in the previous chapter, in our V1__create_table_books.sql file.

create table book
(
    id varchar(255) not null primary key,
    name varchar(255) not null,
    author varchar(255) null,
    price decimal(10, 2) null
);

You can also add a parameter to the application.properties file that specifies where the migrations are located, so Flyway knows the exact path to the migration files:

spring.flyway.locations=classpath:db.migration

After this, run the application, and you should see the table created with the fields you specified in the migration!

You can no longer modify the first version of the migration. For each change to your table, you will need to create a new migration file and add the new script there!

Why are Migrations Important?

Migrations are necessary for orderly management of changes in the database, preserving history and allowing for rollbacks when needed.

They help synchronize the database structure across different environments such as development, testing, and production, while also automating the update process, reducing the risk of errors, and ensuring that the database schema remains consistent with the application code.

Each migration also documents specific changes, making it easier to understand and maintain the database schema.

Summary

Using Flyway simplifies and automates the process of managing database changes, leading to more reliable and efficient application development.

1. What is a database migration?

2. What role do migration versions play?

question mark

What is a database migration?

Select the correct answer

question mark

What role do migration versions play?

Select the correct answer

Tudo estava claro?

Como podemos melhorá-lo?

Obrigado pelo seu feedback!

Seção 4. Capítulo 3
some-alt