migrations.md 33.3 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 348 349 350 351 352 353 354 355 356
`create_join_table` also accepts a block, which you can use to add indices
(which are not created by default) or additional columns:

```ruby
create_join_table :products, :categories do |t|
  t.index :products
  t.index :categories
end
```

357
### Changing Tables
358

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

363
```ruby
364 365 366 367 368 369
change_table :products do |t|
  t.remove :description, :name
  t.string :part_number
  t.index :part_number
  t.rename :upccode, :upc_code
end
370
```
371

372 373
removes the `description` and `name` columns, creates a `part_number` string
column and adds an index on it. Finally it renames the `upccode` column.
374

375
### When Helpers aren't Enough
376

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

380
```ruby
S
Steve Klabnik 已提交
381
Products.connection.execute('UPDATE `products` SET `price`=`free` WHERE 1')
382
```
383

384
For more details and examples of individual methods, check the API documentation.
385
In particular the documentation for
386
[`ActiveRecord::ConnectionAdapters::SchemaStatements`](http://api.rubyonrails.org/classes/ActiveRecord/ConnectionAdapters/SchemaStatements.html)
387
(which provides the methods available in the `change`, `up` and `down` methods),
388
[`ActiveRecord::ConnectionAdapters::TableDefinition`](http://api.rubyonrails.org/classes/ActiveRecord/ConnectionAdapters/TableDefinition.html)
389
(which provides the methods available on the object yielded by `create_table`)
J
Jason Noble 已提交
390
and
391
[`ActiveRecord::ConnectionAdapters::Table`](http://api.rubyonrails.org/classes/ActiveRecord/ConnectionAdapters/Table.html)
392
(which provides the methods available on the object yielded by `change_table`).
393

394
### Using the `change` Method
395

S
Steve Klabnik 已提交
396 397 398 399
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:
400

401 402
* `add_column`
* `add_index`
403
* `add_reference`
404 405
* `add_timestamps`
* `create_table`
406 407 408
* `create_join_table`
* `drop_table` (must supply a block)
* `drop_join_table`  (must supply a block)
409 410 411
* `remove_timestamps`
* `rename_column`
* `rename_index`
412
* `remove_reference`
413
* `rename_table`
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 447 448 449 450 451 452 453 454 455 456
`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
```

457
Using `reversible` will ensure that the instructions are executed in the
458 459 460 461 462 463 464 465 466
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.
467

468
### Using the `up`/`down` Methods
469

470 471
You can also use the old style of migration using `up` and `down` methods
instead of the `change` method.
S
Steve Klabnik 已提交
472 473 474 475 476 477
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
478
made in the `up` method. The example in the `reversible` section is equivalent to:
479

480
```ruby
481
class ExampleMigration < ActiveRecord::Migration
482
  def up
483 484 485
    create_table :products do |t|
      t.references :category
    end
S
Steve Klabnik 已提交
486

L
Lucas Caton 已提交
487
    # add a foreign key
P
Pratik Naik 已提交
488 489 490 491 492 493
    execute <<-SQL
      ALTER TABLE products
        ADD CONSTRAINT fk_products_categories
        FOREIGN KEY (category_id)
        REFERENCES categories(id)
    SQL
S
Steve Klabnik 已提交
494

495 496 497 498
    add_column :users, :home_page_url, :string
    rename_column :users, :email, :email_address
  end

499
  def down
500 501
    rename_column :users, :email_address, :email
    remove_column :users, :home_page_url
S
Steve Klabnik 已提交
502

J
Jason Noble 已提交
503 504 505 506
    execute <<-SQL
      ALTER TABLE products
        DROP FOREIGN KEY fk_products_categories
    SQL
S
Steve Klabnik 已提交
507

508 509 510
    drop_table :products
  end
end
511
```
512

513
If your migration is irreversible, you should raise
514
`ActiveRecord::IrreversibleMigration` from your `down` method. If someone tries
J
Jason Noble 已提交
515 516
to revert your migration, an error message will be displayed saying that it
can't be done.
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 582 583 584 585 586 587 588 589 590 591
### 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`.

592 593
Running Migrations
------------------
594

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

S
Steve Klabnik 已提交
597
The very first migration related Rake task you will use will probably be
598
`rake db:migrate`. In its most basic form it just runs the `change` or `up`
599 600 601
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.
602

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

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

P
Prem Sichanugrist 已提交
611
```bash
612
$ rake db:migrate VERSION=20080906120000
613
```
614

J
Jason Noble 已提交
615
If version 20080906120000 is greater than the current version (i.e., it is
616 617
migrating upwards), this will run the `change` (or `up`) method
on all migrations up to and
V
Vijay Dev 已提交
618
including 20080906120000, and will not execute any later migrations. If
619
migrating downwards, this will run the `down` method on all the migrations
620
down to, but not including, 20080906120000.
621

622
### Rolling Back
623

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

P
Prem Sichanugrist 已提交
628
```bash
629
$ rake db:rollback
630
```
631

632 633
This will rollback the latest migration, either by reverting the `change`
method or by running the `down` method. If you need to undo
634
several migrations you can provide a `STEP` parameter:
635

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

640
will revert the last 3 migrations.
641

642 643
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 已提交
644
if you need to go more than one version back, for example
645

P
Prem Sichanugrist 已提交
646
```bash
647
$ rake db:migrate:redo STEP=3
648
```
649

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

654
### Resetting the Database
655

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

S
Steve Klabnik 已提交
659 660 661 662
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).'
663

664
### Running Specific Migrations
665

666 667
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
668 669
the corresponding migration will have its `change`, `up` or `down` method
invoked, for example,
670

P
Prem Sichanugrist 已提交
671
```bash
672
$ rake db:migrate:up VERSION=20080906120000
673
```
674

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

680 681
### Running Migrations in Different Environments

S
Steve Klabnik 已提交
682 683 684 685
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:
686 687 688 689 690

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

691
### Changing the Output of Running Migrations
692

J
Jason Noble 已提交
693 694
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
695

P
Prem Sichanugrist 已提交
696
```bash
J
Jason Noble 已提交
697
==  CreateProducts: migrating =================================================
698
-- create_table(:products)
J
Jason Noble 已提交
699 700
   -> 0.0028s
==  CreateProducts: migrated (0.0028s) ========================================
701
```
702

703 704
Several methods are provided in migrations that allow you to control all this:

705 706 707 708 709
| 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.
710 711 712

For example, this migration

713
```ruby
714
class CreateProducts < ActiveRecord::Migration
715
  def change
716 717 718 719 720 721 722
    suppress_messages do
      create_table :products do |t|
        t.string :name
        t.text :description
        t.timestamps
      end
    end
S
Steve Klabnik 已提交
723

724
    say "Created a table"
S
Steve Klabnik 已提交
725

726 727
    suppress_messages {add_index :products, :name}
    say "and an index!", true
S
Steve Klabnik 已提交
728

729 730 731 732 733 734
    say_with_time 'Waiting for a while' do
      sleep 10
      250
    end
  end
end
735
```
736 737 738

generates the following output

P
Prem Sichanugrist 已提交
739
```bash
J
Jason Noble 已提交
740 741
==  CreateProducts: migrating =================================================
-- Created a table
742
   -> and an index!
J
Jason Noble 已提交
743 744
-- Waiting for a while
   -> 10.0013s
745
   -> 250 rows
J
Jason Noble 已提交
746
==  CreateProducts: migrated (10.0054s) =======================================
747
```
748

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

S
Steve Klabnik 已提交
752 753 754 755 756 757 758
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
759 760
example with `rake db:rollback`), edit your migration and then run
`rake db:migrate` to run the corrected version.
S
Steve Klabnik 已提交
761 762 763 764 765 766 767 768 769

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.

770 771 772 773
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).

774 775
Using Models in Your Migrations
-------------------------------
776

S
Steve Klabnik 已提交
777 778
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 已提交
779
data. This can be done, but some caution should be observed.
780

J
Jason Noble 已提交
781 782 783
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.
784

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

788 789
Bob goes on vacation.

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

794
```ruby
795 796 797 798
# db/migrate/20100513121110_add_flag_to_product.rb

class AddFlagToProduct < ActiveRecord::Migration
  def change
J
Jason Noble 已提交
799
    add_column :products, :flag, :boolean
800 801 802
    reversible do |dir|
      dir.up { Product.update_all flag: false }
    end
A
Agis Anastasopoulos 已提交
803
    Product.update_all flag: false
804
  end
805
end
806
```
807

808
```ruby
809 810 811
# app/model/product.rb

class Product < ActiveRecord::Base
A
Agis Anastasopoulos 已提交
812
  validates :flag, presence: true
813
end
814
```
815

J
Jason Noble 已提交
816
Alice adds a second migration which adds and initializes another column to the
817
`products` table and also adds a validation to the `Product` model for the new
J
Jason Noble 已提交
818
column.
819

820
```ruby
821 822 823
# db/migrate/20100515121110_add_fuzz_to_product.rb

class AddFuzzToProduct < ActiveRecord::Migration
824
  def change
825
    add_column :products, :fuzz, :string
826 827 828
    reversible do |dir|
      dir.up { Product.update_all fuzz: 'fuzzy' }
    end
829 830
  end
end
831
```
832

833
```ruby
834
# app/model/product.rb
835

836
class Product < ActiveRecord::Base
A
Agis Anastasopoulos 已提交
837
  validates :flag, :fuzz, presence: true
838
end
839
```
840

841 842 843 844
Both migrations work for Alice.

Bob comes back from vacation and:

S
Steve Klabnik 已提交
845 846
*   Updates the source - which contains both migrations and the latest version
    of the Product model.
847 848
*   Runs outstanding migrations with `rake db:migrate`, which
    includes the one that updates the `Product` model.
849

J
Jason Noble 已提交
850 851 852
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:
853

854
```
855 856 857 858
rake aborted!
An error has occurred, this and all later migrations canceled:

undefined method `fuzz' for #<Product:0x000001049b14a0>
859
```
860

S
Steve Klabnik 已提交
861 862
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.
863

S
Steve Klabnik 已提交
864
When using a local model, it's a good idea to call
865 866
`Product.reset_column_information` to refresh the `ActiveRecord` cache for the
`Product` model prior to updating data in the database.
867 868 869

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

870
```ruby
871 872
# db/migrate/20100513121110_add_flag_to_product.rb

V
Vijay Dev 已提交
873
class AddFlagToProduct < ActiveRecord::Migration
874 875
  class Product < ActiveRecord::Base
  end
V
Vijay Dev 已提交
876

877
  def change
878
    add_column :products, :flag, :boolean
V
Vijay Dev 已提交
879
    Product.reset_column_information
880 881 882
    reversible do |dir|
      dir.up { Product.update_all flag: false }
    end
883 884
  end
end
885
```
886

887
```ruby
888 889 890 891 892
# db/migrate/20100515121110_add_fuzz_to_product.rb

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

894
  def change
895
    add_column :products, :fuzz, :string
896
    Product.reset_column_information
897 898 899
    reversible do |dir|
      dir.up { Product.update_all fuzz: 'fuzzy' }
    end
900 901
  end
end
902
```
903

904 905 906
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 已提交
907
updates the `description` field on certain products. She runs the
908
migration, commits the code, and then begins working on the next feature,
S
Steve Klabnik 已提交
909
which is to add a new column `fuzz` to the products table.
910 911

She creates two migrations for this new feature, one which adds the new
S
Steve Klabnik 已提交
912
column, and a second which selectively updates the `fuzz` column based on
913 914 915 916
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 已提交
917 918
subtle bug: The descriptions have defaults, and the `fuzz` column is present,
but `fuzz` is nil on all products.
919

S
Steve Klabnik 已提交
920
The solution is again to use `Product.reset_column_information` before
921 922 923 924
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.

925 926
Schema Dumping and You
----------------------
927

928
### What are Schema Files for?
929

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

J
Jason Noble 已提交
935 936 937
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.
938

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

J
Jason Noble 已提交
943 944
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 已提交
945 946
frequently spread across several migrations, but the information is nicely
summed up in the schema file. The
947
[annotate_models](https://github.com/ctran/annotate_models) gem automatically
V
Vijay Dev 已提交
948
adds and updates comments at the top of each model summarizing the schema if
J
Jason Noble 已提交
949
you desire that functionality.
950

951
### Types of Schema Dumps
952

S
Steve Klabnik 已提交
953 954 955
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`.
956

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

961
```ruby
962 963
ActiveRecord::Schema.define(version: 20080906171750) do
  create_table "authors", force: true do |t|
964 965 966 967 968
    t.string   "name"
    t.datetime "created_at"
    t.datetime "updated_at"
  end

969
  create_table "products", force: true do |t|
970
    t.string   "name"
J
Jason Noble 已提交
971
    t.text "description"
972 973
    t.datetime "created_at"
    t.datetime "updated_at"
J
Jason Noble 已提交
974
    t.string "part_number"
975 976
  end
end
977
```
978

J
Jason Noble 已提交
979
In many ways this is exactly what it is. This file is created by inspecting the
980
database and expressing its structure using `create_table`, `add_index`, and so
J
Jason Noble 已提交
981
on. Because this is database-independent, it could be loaded into any database
S
Steve Klabnik 已提交
982 983
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 已提交
984

985
There is however a trade-off: `db/schema.rb` cannot express database specific
J
Jason Noble 已提交
986 987 988
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
989
this, then you should set the schema format to `:sql`.
J
Jason Noble 已提交
990

S
Steve Klabnik 已提交
991 992 993 994 995
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.
996

997 998 999
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
1000
schema into a RDBMS other than the one used to create it.
1001

1002
### Schema Dumps and Source Control
1003

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

1007 1008
Active Record and Referential Integrity
---------------------------------------
1009

J
Jason Noble 已提交
1010 1011 1012 1013 1014
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 已提交
1015
Validations such as `validates :foreign_key, uniqueness: true` are one way in
S
Steve Klabnik 已提交
1016 1017 1018 1019 1020 1021 1022 1023
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 已提交
1024
could also use some gem like
S
Steve Klabnik 已提交
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 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059
[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.