migrations.md 33.1 KB
Newer Older
1 2
Active Record Migrations
========================
3

4 5 6 7 8
Migrations are a feature of Active Record that allows you to evolve your
database schema over time. Rather than write schema modifications in pure SQL,
migrations allow you to use an easy Ruby DSL to describe changes to your
tables.

9
After reading this guide, you will know:
10

11 12 13 14
* The generators you can use to create them.
* The methods Active Record provides to manipulate your database.
* The Rake tasks that manipulate migrations and your schema.
* How migrations relate to `schema.rb`.
15 16 17

--------------------------------------------------------------------------------

S
Steve Klabnik 已提交
18 19
Migration Overview
------------------
20

S
Steve Klabnik 已提交
21 22 23
Migrations are a convenient way to alter your database schema over time in a
consistent and easy way. They use a Ruby DSL so that you don't have to write
SQL by hand, allowing your schema and changes to be database independent.
J
Jason Noble 已提交
24

S
Steve Klabnik 已提交
25 26 27 28 29
You can think of each migration as being a new 'version' of the database. A
schema starts off with nothing in it, and each migration modifies it to add or
remove tables, columns, or entries. Active Record knows how to update your
schema along this timeline, bringing it from whatever point it is in the
history to the latest version. Active Record will also update your
30
`db/schema.rb` file to match the up-to-date structure of your database.
J
Jason Noble 已提交
31

S
Steve Klabnik 已提交
32
Here's an example of a migration:
33

34
```ruby
35
class CreateProducts < ActiveRecord::Migration
S
Steve Klabnik 已提交
36
  def change
V
Vijay Dev 已提交
37
    create_table :products do |t|
38 39 40 41 42 43 44
      t.string :name
      t.text :description

      t.timestamps
    end
  end
end
45
```
46

S
Steve Klabnik 已提交
47 48 49 50 51 52 53 54 55 56 57 58
This migration adds a table called `products` with a string column called
`name` and a text column called `description`. A primary key column called `id`
will also be added implicitly, as it's the default primary key for all Active
Record models. The `timestamps` macro adds two columns, `created_at` and
`updated_at`. These special columns are automatically managed by Active Record
if they exist.

Note that we define the change that we want to happen moving forward in time.
Before this migration is run, there will be no table. After, the table will
exist. Active Record knows how to reverse this migration as well: if we roll
this migration back, it will remove the table.

59
On databases that support transactions with statements that change the schema,
S
Steve Klabnik 已提交
60 61 62
migrations are wrapped in a transaction. If the database does not support this
then when a migration fails the parts of it that succeeded will not be rolled
back. You will have to rollback the changes that were made by hand.
63

S
Steve Klabnik 已提交
64
If you wish for a migration to do something that Active Record doesn't know how
65
to reverse, you can use `reversible`:
66

67
```ruby
68 69 70 71 72 73 74 75 76 77 78 79 80 81
class ChangeProductsPrice < ActiveRecord::Migration
  def change
    reversible do |dir|
      change_table :products do |t|
        dir.up   { t.change :price, :string }
        dir.down { t.change :price, :integer }
      end
    end
  end
end
```

Alternatively, you can use `up` and `down` instead of `change`:

82
```ruby
S
Steve Klabnik 已提交
83
class ChangeProductsPrice < ActiveRecord::Migration
84
  def up
S
Steve Klabnik 已提交
85
    change_table :products do |t|
86
      t.change :price, :string
87 88
    end
  end
89

90
  def down
S
Steve Klabnik 已提交
91
    change_table :products do |t|
92
      t.change :price, :integer
93 94 95
    end
  end
end
96
```
97

S
Steve Klabnik 已提交
98 99
Creating a Migration
--------------------
100

S
Steve Klabnik 已提交
101
### Creating a Standalone Migration
102

103
Migrations are stored as files in the `db/migrate` directory, one for each
V
Vijay Dev 已提交
104
migration class. The name of the file is of the form
105
`YYYYMMDDHHMMSS_create_products.rb`, that is to say a UTC timestamp
V
Vijay Dev 已提交
106 107
identifying the migration followed by an underscore followed by the name
of the migration. The name of the migration class (CamelCased version)
J
Jason Noble 已提交
108
should match the latter part of the file name. For example
109 110
`20080906120000_create_products.rb` should define class `CreateProducts` and
`20080906120001_add_details_to_products.rb` should define
S
Steve Klabnik 已提交
111 112 113
`AddDetailsToProducts`. Rails uses this timestamp to determine which migration
should be run and in what order, so if you're copying a migration from another
application or generate a file yourself, be aware of its position in the order.
114

S
Steve Klabnik 已提交
115 116
Of course, calculating timestamps is no fun, so Active Record provides a
generator to handle making it for you:
117

P
Prem Sichanugrist 已提交
118
```bash
119
$ rails generate migration AddPartNumberToProducts
120
```
121 122 123

This will create an empty but appropriately named migration:

124
```ruby
125
class AddPartNumberToProducts < ActiveRecord::Migration
126
  def change
127 128
  end
end
129
```
130

J
Jason Noble 已提交
131 132
If the migration name is of the form "AddXXXToYYY" or "RemoveXXXFromYYY" and is
followed by a list of column names and types then a migration containing the
133
appropriate `add_column` and `remove_column` statements will be created.
134

P
Prem Sichanugrist 已提交
135
```bash
136
$ rails generate migration AddPartNumberToProducts part_number:string
137
```
138 139 140

will generate

141
```ruby
142
class AddPartNumberToProducts < ActiveRecord::Migration
143
  def change
144 145 146
    add_column :products, :part_number, :string
  end
end
147
```
148 149 150

Similarly,

P
Prem Sichanugrist 已提交
151
```bash
152
$ rails generate migration RemovePartNumberFromProducts part_number:string
153
```
154 155 156

generates

157
```ruby
158
class RemovePartNumberFromProducts < ActiveRecord::Migration
159 160
  def change
    remove_column :products, :part_number, :string
161 162
  end
end
163
```
164

165
You are not limited to one magically generated column. For example
166

P
Prem Sichanugrist 已提交
167
```bash
168
$ rails generate migration AddDetailsToProducts part_number:string price:decimal
169
```
170 171 172

generates

173
```ruby
174
class AddDetailsToProducts < ActiveRecord::Migration
175
  def change
176 177 178 179
    add_column :products, :part_number, :string
    add_column :products, :price, :decimal
  end
end
180
```
181

J
Jason Noble 已提交
182
As always, what has been generated for you is just a starting point. You can add
V
Vijay Dev 已提交
183
or remove from it as you see fit by editing the
184
`db/migrate/YYYYMMDDHHMMSS_add_details_to_products.rb` file.
185

S
Steve Klabnik 已提交
186 187
Also, the generator accepts column type as `references`(also available as
`belongs_to`). For instance
A
Aleksey Magusev 已提交
188

P
Prem Sichanugrist 已提交
189
```bash
A
Aleksey Magusev 已提交
190
$ rails generate migration AddUserRefToProducts user:references
191
```
A
Aleksey Magusev 已提交
192 193 194

generates

195
```ruby
A
Aleksey Magusev 已提交
196 197
class AddUserRefToProducts < ActiveRecord::Migration
  def change
A
Agis Anastasopoulos 已提交
198
    add_reference :products, :user, index: true
A
Aleksey Magusev 已提交
199 200
  end
end
201
```
A
Aleksey Magusev 已提交
202

S
Steve Klabnik 已提交
203 204
This migration will create a `user_id` column and appropriate index.

205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223
There is also a generator which will produce join tables if `JoinTable` is part of the name:

```bash
rails g migration CreateJoinTableCustomerProduct customer product
```

will produce the following migration:

```ruby
class CreateJoinTableCustomerProduct < ActiveRecord::Migration
  def change
    create_join_table :customers, :products do |t|
      # t.index [:customer_id, :product_id]
      # t.index [:product_id, :customer_id]
    end
  end
end
```

S
Steve Klabnik 已提交
224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250
### Model Generators

The model and scaffold generators will create migrations appropriate for adding
a new model. This migration will already contain instructions for creating the
relevant table. If you tell Rails what columns you want, then statements for
adding these columns will also be created. For example, running

```bash
$ rails generate model Product name:string description:text
```

will create a migration that looks like this

```ruby
class CreateProducts < ActiveRecord::Migration
  def change
    create_table :products do |t|
      t.string :name
      t.text :description

      t.timestamps
    end
  end
end
```

You can append as many column name/type pairs as you want.
A
Aleksey Magusev 已提交
251

252
### Supported Type Modifiers
A
Aleksey Magusev 已提交
253

S
Steve Klabnik 已提交
254 255
You can also specify some options just after the field type between curly
braces. You can use the following modifiers:
A
Aleksey Magusev 已提交
256

257 258 259 260
* `limit`        Sets the maximum size of the `string/text/binary/integer` fields
* `precision`    Defines the precision for the `decimal` fields
* `scale`        Defines the scale for the `decimal` fields
* `polymorphic`  Adds a `type` column for `belongs_to` associations
A
Aleksey Magusev 已提交
261

262
For instance, running
A
Aleksey Magusev 已提交
263

P
Prem Sichanugrist 已提交
264
```bash
A
Aleksey Magusev 已提交
265
$ rails generate migration AddDetailsToProducts price:decimal{5,2} supplier:references{polymorphic}
266
```
A
Aleksey Magusev 已提交
267 268 269

will produce a migration that looks like this

270
```ruby
A
Aleksey Magusev 已提交
271 272
class AddDetailsToProducts < ActiveRecord::Migration
  def change
A
Agis Anastasopoulos 已提交
273 274
    add_column :products, :price, precision: 5, scale: 2
    add_reference :products, :user, polymorphic: true, index: true
A
Aleksey Magusev 已提交
275 276
  end
end
277
```
A
Aleksey Magusev 已提交
278

279 280
Writing a Migration
-------------------
281

J
Jason Noble 已提交
282 283
Once you have created your migration using one of the generators it's time to
get to work!
284

285
### Creating a Table
286

S
Steve Klabnik 已提交
287 288 289
The `create_table` method is one of the most fundamental, but most of the time,
will be generated for you from using a model or scaffold generator. A typical
use would be
290

291
```ruby
292 293 294
create_table :products do |t|
  t.string :name
end
295
```
296

297 298
which creates a `products` table with a column called `name` (and as discussed
below, an implicit `id` column).
299

300 301
By default, `create_table` will create a primary key called `id`. You can change
the name of the primary key with the `:primary_key` option (don't forget to
S
Steve Klabnik 已提交
302 303 304
update the corresponding model) or, if you don't want a primary key at all, you
can pass the option `id: false`. If you need to pass database specific options
you can place an SQL fragment in the `:options` option. For example,
305

306
```ruby
A
Agis Anastasopoulos 已提交
307 308
create_table :products, options: "ENGINE=BLACKHOLE" do |t|
  t.string :name, null: false
309
end
310
```
311

312 313
will append `ENGINE=BLACKHOLE` to the SQL statement used to create the table
(when using MySQL, the default is `ENGINE=InnoDB`).
P
Pratik Naik 已提交
314

315
### Creating a Join Table
316

317
Migration method `create_join_table` creates a HABTM join table. A typical use
318 319
would be

320
```ruby
321
create_join_table :products, :categories
322
```
323

S
Steve Klabnik 已提交
324 325 326
which creates a `categories_products` table with two columns called
`category_id` and `product_id`. These columns have the option `:null` set to
`false` by default.
327

S
Steve Klabnik 已提交
328 329
You can pass the option `:table_name` with you want to customize the table
name. For example,
330

331
```ruby
A
Agis Anastasopoulos 已提交
332
create_join_table :products, :categories, table_name: :categorization
333
```
334

335
will create a `categorization` table.
336

S
Steve Klabnik 已提交
337 338
By default, `create_join_table` will create two columns with no options, but
you can specify these options using the `:column_options` option. For example,
339

340
```ruby
A
Agis Anastasopoulos 已提交
341
create_join_table :products, :categories, column_options: {null: true}
342
```
343

S
Steve Klabnik 已提交
344 345
will create the `product_id` and `category_id` with the `:null` option as
`true`.
346

347
### Changing Tables
348

349
A close cousin of `create_table` is `change_table`, used for changing existing
S
Steve Klabnik 已提交
350 351
tables. It is used in a similar fashion to `create_table` but the object
yielded to the block knows more tricks. For example
352

353
```ruby
354 355 356 357 358 359
change_table :products do |t|
  t.remove :description, :name
  t.string :part_number
  t.index :part_number
  t.rename :upccode, :upc_code
end
360
```
361

362 363
removes the `description` and `name` columns, creates a `part_number` string
column and adds an index on it. Finally it renames the `upccode` column.
364

365
### When Helpers aren't Enough
366

S
Steve Klabnik 已提交
367 368
If the helpers provided by Active Record aren't enough you can use the `execute`
method to execute arbitrary SQL:
369

370
```ruby
S
Steve Klabnik 已提交
371
Products.connection.execute('UPDATE `products` SET `price`=`free` WHERE 1')
372
```
373

374
For more details and examples of individual methods, check the API documentation.
375
In particular the documentation for
376
[`ActiveRecord::ConnectionAdapters::SchemaStatements`](http://api.rubyonrails.org/classes/ActiveRecord/ConnectionAdapters/SchemaStatements.html)
377
(which provides the methods available in the `change`, `up` and `down` methods),
378
[`ActiveRecord::ConnectionAdapters::TableDefinition`](http://api.rubyonrails.org/classes/ActiveRecord/ConnectionAdapters/TableDefinition.html)
379
(which provides the methods available on the object yielded by `create_table`)
J
Jason Noble 已提交
380
and
381
[`ActiveRecord::ConnectionAdapters::Table`](http://api.rubyonrails.org/classes/ActiveRecord/ConnectionAdapters/Table.html)
382
(which provides the methods available on the object yielded by `change_table`).
383

384
### Using the `change` Method
385

S
Steve Klabnik 已提交
386 387 388 389
The `change` method is the primary way of writing migrations. It works for the
majority of cases, where Active Record knows how to reverse the migration
automatically. Currently, the `change` method supports only these migration
definitions:
390

391 392
* `add_column`
* `add_index`
393
* `add_reference`
394 395
* `add_timestamps`
* `create_table`
396 397 398
* `create_join_table`
* `drop_table` (must supply a block)
* `drop_join_table`  (must supply a block)
399 400 401
* `remove_timestamps`
* `rename_column`
* `rename_index`
402
* `remove_reference`
403
* `rename_table`
404

405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446
`change_table` is also reversible, as long as the block does not call `change`,
`change_default` or `remove`.

If you're going to need to use any other methods, you should use `reversible`
or write the `up` and `down` methods instead of using the `change` method.

### Using `reversible`

Complex migrations may require processing that Active Record doesn't know how
to reverse. You can use `reversible` to specify what to do when running a
migration what else to do when reverting it. For example,

```ruby
class ExampleMigration < ActiveRecord::Migration
  def change
    create_table :products do |t|
      t.references :category
    end

    reversible do |dir|
      dir.up do
        #add a foreign key
        execute <<-SQL
          ALTER TABLE products
            ADD CONSTRAINT fk_products_categories
            FOREIGN KEY (category_id)
            REFERENCES categories(id)
        SQL
      end
      dir.down do
        execute <<-SQL
          ALTER TABLE products
            DROP FOREIGN KEY fk_products_categories
        SQL
      end
    end

    add_column :users, :home_page_url, :string
    rename_column :users, :email, :email_address
  end
```

447
Using `reversible` will ensure that the instructions are executed in the
448 449 450 451 452 453 454 455 456
right order too. If the previous example migration is reverted,
the `down` block will be run after the `home_page_url` column is removed and
right before the table `products` is dropped.

Sometimes your migration will do something which is just plain irreversible; for
example, it might destroy some data. In such cases, you can raise
`ActiveRecord::IrreversibleMigration` in your `down` block. If someone tries
to revert your migration, an error message will be displayed saying that it
can't be done.
457

458
### Using the `up`/`down` Methods
459

460 461
You can also use the old style of migration using `up` and `down` methods
instead of the `change` method.
S
Steve Klabnik 已提交
462 463 464 465 466 467
The `up` method should describe the transformation you'd like to make to your
schema, and the `down` method of your migration should revert the
transformations done by the `up` method. In other words, the database schema
should be unchanged if you do an `up` followed by a `down`. For example, if you
create a table in the `up` method, you should drop it in the `down` method. It
is wise to reverse the transformations in precisely the reverse order they were
468
made in the `up` method. The example in the `reversible` section is equivalent to:
469

470
```ruby
471
class ExampleMigration < ActiveRecord::Migration
472
  def up
473 474 475
    create_table :products do |t|
      t.references :category
    end
S
Steve Klabnik 已提交
476

L
Lucas Caton 已提交
477
    # add a foreign key
P
Pratik Naik 已提交
478 479 480 481 482 483
    execute <<-SQL
      ALTER TABLE products
        ADD CONSTRAINT fk_products_categories
        FOREIGN KEY (category_id)
        REFERENCES categories(id)
    SQL
S
Steve Klabnik 已提交
484

485 486 487 488
    add_column :users, :home_page_url, :string
    rename_column :users, :email, :email_address
  end

489
  def down
490 491
    rename_column :users, :email_address, :email
    remove_column :users, :home_page_url
S
Steve Klabnik 已提交
492

J
Jason Noble 已提交
493 494 495 496
    execute <<-SQL
      ALTER TABLE products
        DROP FOREIGN KEY fk_products_categories
    SQL
S
Steve Klabnik 已提交
497

498 499 500
    drop_table :products
  end
end
501
```
502

503
If your migration is irreversible, you should raise
504
`ActiveRecord::IrreversibleMigration` from your `down` method. If someone tries
J
Jason Noble 已提交
505 506
to revert your migration, an error message will be displayed saying that it
can't be done.
507

508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581
### Reverting Previous Migrations

You can use Active Record's ability to rollback migrations using the `revert` method:

```ruby
require_relative '2012121212_example_migration'

class FixupExampleMigration < ActiveRecord::Migration
  def change
    revert ExampleMigration

    create_table(:apples) do |t|
      t.string :variety
    end
  end
end
```

The `revert` method also accepts a block of instructions to reverse.
This could be useful to revert selected parts of previous migrations.
For example, let's imagine that `ExampleMigration` is committed and it
is later decided it would be best to serialize the product list instead.
One could write:

```ruby
class SerializeProductListMigration < ActiveRecord::Migration
  def change
    add_column :categories, :product_list

    reversible do |dir|
      dir.up do
        # transfer data from Products to Category#product_list
      end
      dir.down do
        # create Products from Category#product_list
      end
    end

    revert do
      # copy-pasted code from ExampleMigration
      create_table :products do |t|
        t.references :category
      end

      reversible do |dir|
        dir.up do
          #add a foreign key
          execute <<-SQL
            ALTER TABLE products
              ADD CONSTRAINT fk_products_categories
              FOREIGN KEY (category_id)
              REFERENCES categories(id)
          SQL
        end
        dir.down do
          execute <<-SQL
            ALTER TABLE products
              DROP FOREIGN KEY fk_products_categories
          SQL
        end
      end

      # The rest of the migration was ok
    end
  end
end
```

The same migration could also have been written without using `revert`
but this would have involved a few more steps: reversing the order
of `create_table` and `reversible`, replacing `create_table`
by `drop_table`, and finally replacing `up` by `down` and vice-versa.
This is all taken care of by `revert`.

582 583
Running Migrations
------------------
584

S
Steve Klabnik 已提交
585
Rails provides a set of Rake tasks to run certain sets of migrations.
586

S
Steve Klabnik 已提交
587
The very first migration related Rake task you will use will probably be
588
`rake db:migrate`. In its most basic form it just runs the `change` or `up`
589 590 591
method for all the migrations that have not yet been run. If there are
no such migrations, it exits. It will run these migrations in order based
on the date of the migration.
592

593
Note that running the `db:migrate` also invokes the `db:schema:dump` task, which
1
1334 已提交
594
will update your `db/schema.rb` file to match the structure of your database.
595

J
Jason Noble 已提交
596
If you specify a target version, Active Record will run the required migrations
597
(change, up, down) until it has reached the specified version. The version
V
Vijay Dev 已提交
598
is the numerical prefix on the migration's filename. For example, to migrate
599
to version 20080906120000 run
600

P
Prem Sichanugrist 已提交
601
```bash
602
$ rake db:migrate VERSION=20080906120000
603
```
604

J
Jason Noble 已提交
605
If version 20080906120000 is greater than the current version (i.e., it is
606 607
migrating upwards), this will run the `change` (or `up`) method
on all migrations up to and
V
Vijay Dev 已提交
608
including 20080906120000, and will not execute any later migrations. If
609
migrating downwards, this will run the `down` method on all the migrations
610
down to, but not including, 20080906120000.
611

612
### Rolling Back
613

614
A common task is to rollback the last migration. For example, if you made a
J
Jason Noble 已提交
615 616
mistake in it and wish to correct it. Rather than tracking down the version
number associated with the previous migration you can run
617

P
Prem Sichanugrist 已提交
618
```bash
619
$ rake db:rollback
620
```
621

622 623
This will rollback the latest migration, either by reverting the `change`
method or by running the `down` method. If you need to undo
624
several migrations you can provide a `STEP` parameter:
625

P
Prem Sichanugrist 已提交
626
```bash
627
$ rake db:rollback STEP=3
628
```
629

630
will revert the last 3 migrations.
631

632 633
The `db:migrate:redo` task is a shortcut for doing a rollback and then migrating
back up again. As with the `db:rollback` task, you can use the `STEP` parameter
J
Jason Noble 已提交
634
if you need to go more than one version back, for example
635

P
Prem Sichanugrist 已提交
636
```bash
637
$ rake db:migrate:redo STEP=3
638
```
639

640
Neither of these Rake tasks do anything you could not do with `db:migrate`. They
J
Jason Noble 已提交
641 642
are simply more convenient, since you do not need to explicitly specify the
version to migrate to.
643

644
### Resetting the Database
645

646
The `rake db:reset` task will drop the database, recreate it and load the
J
Jason Noble 已提交
647
current schema into it.
648

S
Steve Klabnik 已提交
649 650 651 652
NOTE: This is not the same as running all the migrations. It will only use the
contents of the current schema.rb file. If a migration can't be rolled back,
'rake db:reset' may not help you. To find out more about dumping the schema see
'[schema dumping and you](#schema-dumping-and-you).'
653

654
### Running Specific Migrations
655

656 657
If you need to run a specific migration up or down, the `db:migrate:up` and
`db:migrate:down` tasks will do that. Just specify the appropriate version and
658 659
the corresponding migration will have its `change`, `up` or `down` method
invoked, for example,
660

P
Prem Sichanugrist 已提交
661
```bash
662
$ rake db:migrate:up VERSION=20080906120000
663
```
664

665 666
will run the 20080906120000 migration by running the `change` method (or the
`up` method). This task will
S
Steve Klabnik 已提交
667 668
first check whether the migration is already performed and will do nothing if
Active Record believes that it has already been run.
669

670 671
### Running Migrations in Different Environments

S
Steve Klabnik 已提交
672 673 674 675
By default running `rake db:migrate` will run in the `development` environment.
To run migrations against another environment you can specify it using the
`RAILS_ENV` environment variable while running the command. For example to run
migrations against the `test` environment you could run:
676 677 678 679 680

```bash
$ rake db:migrate RAILS_ENV=test
```

681
### Changing the Output of Running Migrations
682

J
Jason Noble 已提交
683 684
By default migrations tell you exactly what they're doing and how long it took.
A migration creating a table and adding an index might produce output like this
685

P
Prem Sichanugrist 已提交
686
```bash
J
Jason Noble 已提交
687
==  CreateProducts: migrating =================================================
688
-- create_table(:products)
J
Jason Noble 已提交
689 690
   -> 0.0028s
==  CreateProducts: migrated (0.0028s) ========================================
691
```
692

693 694
Several methods are provided in migrations that allow you to control all this:

695 696 697 698 699
| Method               | Purpose
| -------------------- | -------
| suppress_messages    | Takes a block as an argument and suppresses any output generated by the block.
| say                  | Takes a message argument and outputs it as is. A second boolean argument can be passed to specify whether to indent or not.
| say_with_time        | Outputs text along with how long it took to run its block. If the block returns an integer it assumes it is the number of rows affected.
700 701 702

For example, this migration

703
```ruby
704
class CreateProducts < ActiveRecord::Migration
705
  def change
706 707 708 709 710 711 712
    suppress_messages do
      create_table :products do |t|
        t.string :name
        t.text :description
        t.timestamps
      end
    end
S
Steve Klabnik 已提交
713

714
    say "Created a table"
S
Steve Klabnik 已提交
715

716 717
    suppress_messages {add_index :products, :name}
    say "and an index!", true
S
Steve Klabnik 已提交
718

719 720 721 722 723 724
    say_with_time 'Waiting for a while' do
      sleep 10
      250
    end
  end
end
725
```
726 727 728

generates the following output

P
Prem Sichanugrist 已提交
729
```bash
J
Jason Noble 已提交
730 731
==  CreateProducts: migrating =================================================
-- Created a table
732
   -> and an index!
J
Jason Noble 已提交
733 734
-- Waiting for a while
   -> 10.0013s
735
   -> 250 rows
J
Jason Noble 已提交
736
==  CreateProducts: migrated (10.0054s) =======================================
737
```
738

739 740
If you want Active Record to not output anything, then running `rake db:migrate
VERBOSE=false` will suppress all output.
741

S
Steve Klabnik 已提交
742 743 744 745 746 747 748
Changing Existing Migrations
----------------------------

Occasionally you will make a mistake when writing a migration. If you have
already run the migration then you cannot just edit the migration and run the
migration again: Rails thinks it has already run the migration and so will do
nothing when you run `rake db:migrate`. You must rollback the migration (for
749 750
example with `rake db:rollback`), edit your migration and then run
`rake db:migrate` to run the corrected version.
S
Steve Klabnik 已提交
751 752 753 754 755 756 757 758 759

In general, editing existing migrations is not a good idea. You will be
creating extra work for yourself and your co-workers and cause major headaches
if the existing version of the migration has already been run on production
machines. Instead, you should write a new migration that performs the changes
you require. Editing a freshly generated migration that has not yet been
committed to source control (or, more generally, which has not been propagated
beyond your development machine) is relatively harmless.

760 761 762 763
The `revert` method can be helpful when writing a new migration to undo
previous migrations in whole or in part
(see [Reverting Previous Migrations](#reverting-previous-migrations) above).

764 765
Using Models in Your Migrations
-------------------------------
766

S
Steve Klabnik 已提交
767 768
When creating or updating data in a migration it is often tempting to use one
of your models. After all, they exist to provide easy access to the underlying
J
Jason Noble 已提交
769
data. This can be done, but some caution should be observed.
770

J
Jason Noble 已提交
771 772 773
For example, problems occur when the model uses database columns which are (1)
not currently in the database and (2) will be created by this or a subsequent
migration.
774

J
Jason Noble 已提交
775
Consider this example, where Alice and Bob are working on the same code base
776
which contains a `Product` model:
777

778 779
Bob goes on vacation.

780
Alice creates a migration for the `products` table which adds a new column and
S
Steve Klabnik 已提交
781
initializes it. She also adds a validation to the `Product` model for the new
J
Jason Noble 已提交
782
column.
783

784
```ruby
785 786 787 788
# db/migrate/20100513121110_add_flag_to_product.rb

class AddFlagToProduct < ActiveRecord::Migration
  def change
J
Jason Noble 已提交
789
    add_column :products, :flag, :boolean
790 791 792
    reversible do |dir|
      dir.up { Product.update_all flag: false }
    end
A
Agis Anastasopoulos 已提交
793
    Product.update_all flag: false
794
  end
795
end
796
```
797

798
```ruby
799 800 801
# app/model/product.rb

class Product < ActiveRecord::Base
A
Agis Anastasopoulos 已提交
802
  validates :flag, presence: true
803
end
804
```
805

J
Jason Noble 已提交
806
Alice adds a second migration which adds and initializes another column to the
807
`products` table and also adds a validation to the `Product` model for the new
J
Jason Noble 已提交
808
column.
809

810
```ruby
811 812 813
# db/migrate/20100515121110_add_fuzz_to_product.rb

class AddFuzzToProduct < ActiveRecord::Migration
814
  def change
815
    add_column :products, :fuzz, :string
816 817 818
    reversible do |dir|
      dir.up { Product.update_all fuzz: 'fuzzy' }
    end
819 820
  end
end
821
```
822

823
```ruby
824
# app/model/product.rb
825

826
class Product < ActiveRecord::Base
A
Agis Anastasopoulos 已提交
827
  validates :flag, :fuzz, presence: true
828
end
829
```
830

831 832 833 834
Both migrations work for Alice.

Bob comes back from vacation and:

S
Steve Klabnik 已提交
835 836
*   Updates the source - which contains both migrations and the latest version
    of the Product model.
837 838
*   Runs outstanding migrations with `rake db:migrate`, which
    includes the one that updates the `Product` model.
839

J
Jason Noble 已提交
840 841 842
The migration crashes because when the model attempts to save, it tries to
validate the second added column, which is not in the database when the _first_
migration runs:
843

844
```
845 846 847 848
rake aborted!
An error has occurred, this and all later migrations canceled:

undefined method `fuzz' for #<Product:0x000001049b14a0>
849
```
850

S
Steve Klabnik 已提交
851 852
A fix for this is to create a local model within the migration. This keeps
Rails from running the validations, so that the migrations run to completion.
853

S
Steve Klabnik 已提交
854
When using a local model, it's a good idea to call
855 856
`Product.reset_column_information` to refresh the `ActiveRecord` cache for the
`Product` model prior to updating data in the database.
857 858 859

If Alice had done this instead, there would have been no problem:

860
```ruby
861 862
# db/migrate/20100513121110_add_flag_to_product.rb

V
Vijay Dev 已提交
863
class AddFlagToProduct < ActiveRecord::Migration
864 865
  class Product < ActiveRecord::Base
  end
V
Vijay Dev 已提交
866

867
  def change
868
    add_column :products, :flag, :boolean
V
Vijay Dev 已提交
869
    Product.reset_column_information
870 871 872
    reversible do |dir|
      dir.up { Product.update_all flag: false }
    end
873 874
  end
end
875
```
876

877
```ruby
878 879 880 881 882
# db/migrate/20100515121110_add_fuzz_to_product.rb

class AddFuzzToProduct < ActiveRecord::Migration
  class Product < ActiveRecord::Base
  end
V
Vijay Dev 已提交
883

884
  def change
885
    add_column :products, :fuzz, :string
886
    Product.reset_column_information
887 888 889
    reversible do |dir|
      dir.up { Product.update_all fuzz: 'fuzzy' }
    end
890 891
  end
end
892
```
893

894 895 896
There are other ways in which the above example could have gone badly.

For example, imagine that Alice creates a migration that selectively
S
Steve Klabnik 已提交
897
updates the `description` field on certain products. She runs the
898
migration, commits the code, and then begins working on the next feature,
S
Steve Klabnik 已提交
899
which is to add a new column `fuzz` to the products table.
900 901

She creates two migrations for this new feature, one which adds the new
S
Steve Klabnik 已提交
902
column, and a second which selectively updates the `fuzz` column based on
903 904 905 906
other product attributes.

These migrations run just fine, but when Bob comes back from his vacation
and calls `rake db:migrate` to run all the outstanding migrations, he gets a
S
Steve Klabnik 已提交
907 908
subtle bug: The descriptions have defaults, and the `fuzz` column is present,
but `fuzz` is nil on all products.
909

S
Steve Klabnik 已提交
910
The solution is again to use `Product.reset_column_information` before
911 912 913 914
referencing the Product model in a migration, ensuring the Active Record's
knowledge of the table structure is current before manipulating data in those
records.

915 916
Schema Dumping and You
----------------------
917

918
### What are Schema Files for?
919

J
Jason Noble 已提交
920
Migrations, mighty as they may be, are not the authoritative source for your
921
database schema. That role falls to either `db/schema.rb` or an SQL file which
J
Jason Noble 已提交
922 923
Active Record generates by examining the database. They are not designed to be
edited, they just represent the current state of the database.
924

J
Jason Noble 已提交
925 926 927
There is no need (and it is error prone) to deploy a new instance of an app by
replaying the entire migration history. It is much simpler and faster to just
load into the database a description of the current schema.
928

J
Jason Noble 已提交
929
For example, this is how the test database is created: the current development
930
database is dumped (either to `db/schema.rb` or `db/structure.sql`) and then
J
Jason Noble 已提交
931
loaded into the test database.
932

J
Jason Noble 已提交
933 934
Schema files are also useful if you want a quick look at what attributes an
Active Record object has. This information is not in the model's code and is
V
Vijay Dev 已提交
935 936
frequently spread across several migrations, but the information is nicely
summed up in the schema file. The
937
[annotate_models](https://github.com/ctran/annotate_models) gem automatically
V
Vijay Dev 已提交
938
adds and updates comments at the top of each model summarizing the schema if
J
Jason Noble 已提交
939
you desire that functionality.
940

941
### Types of Schema Dumps
942

S
Steve Klabnik 已提交
943 944 945
There are two ways to dump the schema. This is set in `config/application.rb`
by the `config.active_record.schema_format` setting, which may be either `:sql`
or `:ruby`.
946

947
If `:ruby` is selected then the schema is stored in `db/schema.rb`. If you look
S
Steve Klabnik 已提交
948 949
at this file you'll find that it looks an awful lot like one very big
migration:
950

951
```ruby
952 953
ActiveRecord::Schema.define(version: 20080906171750) do
  create_table "authors", force: true do |t|
954 955 956 957 958
    t.string   "name"
    t.datetime "created_at"
    t.datetime "updated_at"
  end

959
  create_table "products", force: true do |t|
960
    t.string   "name"
J
Jason Noble 已提交
961
    t.text "description"
962 963
    t.datetime "created_at"
    t.datetime "updated_at"
J
Jason Noble 已提交
964
    t.string "part_number"
965 966
  end
end
967
```
968

J
Jason Noble 已提交
969
In many ways this is exactly what it is. This file is created by inspecting the
970
database and expressing its structure using `create_table`, `add_index`, and so
J
Jason Noble 已提交
971
on. Because this is database-independent, it could be loaded into any database
S
Steve Klabnik 已提交
972 973
that Active Record supports. This could be very useful if you were to
distribute an application that is able to run against multiple databases.
J
Jason Noble 已提交
974

975
There is however a trade-off: `db/schema.rb` cannot express database specific
J
Jason Noble 已提交
976 977 978
items such as foreign key constraints, triggers, or stored procedures. While in
a migration you can execute custom SQL statements, the schema dumper cannot
reconstitute those statements from the database. If you are using features like
979
this, then you should set the schema format to `:sql`.
J
Jason Noble 已提交
980

S
Steve Klabnik 已提交
981 982 983 984 985
Instead of using Active Record's schema dumper, the database's structure will
be dumped using a tool specific to the database (via the `db:structure:dump`
Rake task) into `db/structure.sql`. For example, for PostgreSQL, the `pg_dump`
utility is used. For MySQL, this file will contain the output of `SHOW CREATE
TABLE` for the various tables.
986

987 988 989
Loading these schemas is simply a question of executing the SQL statements they
contain. By definition, this will create a perfect copy of the database's
structure. Using the `:sql` schema format will, however, prevent loading the
990
schema into a RDBMS other than the one used to create it.
991

992
### Schema Dumps and Source Control
993

J
Jason Noble 已提交
994 995
Because schema dumps are the authoritative source for your database schema, it
is strongly recommended that you check them into source control.
996

997 998
Active Record and Referential Integrity
---------------------------------------
999

J
Jason Noble 已提交
1000 1001 1002 1003 1004
The Active Record way claims that intelligence belongs in your models, not in
the database. As such, features such as triggers or foreign key constraints,
which push some of that intelligence back into the database, are not heavily
used.

A
Agis Anastasopoulos 已提交
1005
Validations such as `validates :foreign_key, uniqueness: true` are one way in
S
Steve Klabnik 已提交
1006 1007 1008 1009 1010 1011 1012 1013
which models can enforce data integrity. The `:dependent` option on
associations allows models to automatically destroy child objects when the
parent is destroyed. Like anything which operates at the application level,
these cannot guarantee referential integrity and so some people augment them
with foreign key constraints in the database.

Although Active Record does not provide any tools for working directly with
such features, the `execute` method can be used to execute arbitrary SQL. You
L
Lucas Caton 已提交
1014
could also use some gem like
S
Steve Klabnik 已提交
1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047 1048 1049
[foreigner](https://github.com/matthuhiggins/foreigner) which add foreign key
support to Active Record (including support for dumping foreign keys in
`db/schema.rb`).

Migrations and Seed Data
------------------------

Some people use migrations to add data to the database:

```ruby
class AddInitialProducts < ActiveRecord::Migration
  def up
    5.times do |i|
      Product.create(name: "Product ##{i}", description: "A product.")
    end
  end

  def down
    Product.delete_all
  end
end
```

However, Rails has a 'seeds' feature that should be used for seeding a database
with initial data. It's a really simple feature: just fill up `db/seeds.rb`
with some Ruby code, and run `rake db:seed`:

```ruby
5.times do |i|
  Product.create(name: "Product ##{i}", description: "A product.")
end
```

This is generally a much cleaner way to set up the database of a blank
application.