Как отменить все миграции сразу в Ruby on Rails 3? - PullRequest
16 голосов
/ 09 декабря 2010

Я попытался запустить:

rake db:migrate VERSION=0

Отменяет все миграции , кроме последней .

Затем я попытался запустить:

rake db:migrate:down VERSION=<timestamp_of_last_migration>

но это не вернулось также.Почему?

Есть ли команда, которая запускает все down методы одновременно?

Ответы [ 4 ]

11 голосов
/ 09 декабря 2010

Если ваша база данных имеет отношение только к этому проекту, и вы пытаетесь отменить все в своих миграциях, я просто отбрасываю базу данных и запускаю rake db: create.

Тогда у вас есть пустая база данных, готовая к работе.

Или есть другая причина, по которой вы пытаетесь запустить скрипты down?

10 голосов
/ 09 декабря 2010

Вы можете проверить этот список.

Может быть, это может помочь вам

rake db:create[:all]: If :all not specified then create the database defined in config/database.yml for the current RAILS_ENV. If :all is specified then create all of the databases defined in config/database.yml.
rake db:fixtures:load: Load fixtures into the current environment's database. Load specific fixtures using FIXTURES=x,y
rake db:migrate [VERSION=n]: Migrate the database through scripts in db/migrate. Target specific version with VERSION=n
rake db:migrate:redo [STEP=n]: (2.0.2) Revert the database by rolling back "STEP" number of VERSIONS and re-applying migrations.
rake db:migrate:reset: (2.0.2) Drop the database, create it and then re-apply all migrations. The considerations outlined in the note to rake db:create apply.
rake db:reset: Drop and re-create database using db/schema.rb. The considerations outlined in the note to rake db:create apply.
rake db:rollback [STEP=N]: (2.0.2) Revert migration 1 or n STEPs back.
rake db:schema:dump: Create a db/schema.rb file that can be portably used against any DB supported by AR
rake db:schema:load: Load a schema.rb file into the database
rake db:sessions:clear: Clear the sessions table
rake db:sessions:create: Creates a sessions table for use with CGI::Session::ActiveRecordStore
rake db:structure:dump: Dump the database structure to a SQL file
rake db:test:clone: Recreate the test database from the current environment's database schema
rake db:test:clone_structure: Recreate the test databases from the development structure
rake db:test:prepare: Prepare the test database and load the schema
rake db:test:purge: Empty the test database
7 голосов
/ 26 сентября 2013

есть другой способ:

rake db:rollback STEP=100

это вернет 100 последних миграций

, взятых из http://guides.rubyonrails.org/migrations.html#rolling-back

2 голосов
/ 31 января 2011

попробовать:

rake db:migrate:down VERSION=<timestamp_of_first_migration>

это запустит self.down для вашей первой миграции, по сути уничтожив все. по крайней мере, это только для меня!

...