January 1, 2023 By Matthew Rathbone

Introduction to Rails Migrations

Migrations are a way to make changes to the structure of a database, such as creating, modifying, or deleting tables and columns. They are an important tool for managing the evolution of a database over time, as the application that uses the database changes and grows.

Generating a New Migration

To create a new migration, you can use the rails generate migration command followed by a name for the migration. For example, to create a migration to create a new table called “products”, you might run the following command:

rails generate migration create_products

This will create a new file in the db/migrate directory of your Rails project, with a name like YYYYMMDDHHMMSS_create_products.rb. The timestamp at the beginning of the file name ensures that the migration files are executed in the correct order.

Defining the Migration

Inside the Migration File

Inside the migration file, you will find a class with a change method. This method is where you can define the changes that you want to make to the database. To create a new table, you can use the create_table method, which takes a block of code that defines the columns and their types for the table. For example:

class CreateProducts < ActiveRecord::Migration[6.0]
  def change
    create_table :products do |t|
      t.string :name
      t.text :description
      t.integer :price
      t.timestamps
    end
  end
end

Example: Creating the Products Table

This migration will create a new table called “products” with four columns: “name”, “description”, “price”, and “created_at” and “updated_at” (which are automatically added by the timestamps method).

Running the Migration

To actually apply the changes defined in the migration, you need to run the rails db:migrate command. This will execute all of the pending migrations and update the database schema to reflect the changes.

Conclusion

Migrations are a powerful and convenient way to manage changes to a database, and they are an essential part of the Ruby on Rails framework. By using the rails generate migration command and writing code to define the changes you want to make, you can easily and safely modify the structure of your database as your application evolves.

Beekeeper Studio is the SQL editor and database manager of your dreams

Tried a few tools. Beekeeper was the only one that I found that felt right. Most had a very 1990's feel to them - Allan

I built Beekeeper Studio because, like Allan, I wanted something more intuitive and modern than all the existing clunky apps I could find. My customers agree - they love using Beekeeper and they tell me every day! Give it a try, I bet you'll like it too.

Beekeeper's Linux version is 100% full-featured, no cut corners, no feature compromises.