开发者

How do I add columns to devise after the initial create_table rake?

开发者 https://www.devze.com 2023-03-12 23:48 出处:网络
I installed Devise, raked, and then realized afterwards, that I want to add :confirmable. Can I go back to the same initial migration and just uncomment out the helper that I want and then rake db:mi

I installed Devise, raked, and then realized afterwards, that I want to add :confirmable.

Can I go back to the same initial migration and just uncomment out the helper that I want and then rake db:migrate again?

I trie开发者_JS百科d it and it didn't seem to work. But I haven't seen an example of how to create a follow-on migration.

Thanks!

This is what I tried:

  1 class AddConfirmableToUsers < ActiveRecord::Migration 
  2   def self.up 
  3     change_table :users do |t| 
  4       t.confirmable 
  5     end 
  6     add_index :users, :confirmation_token,   :unique => true  
  7   end 
  8    
  9   def self.down 
 10     remove_column :users, :confirmation_token 
 11   end 
 12   
 13 end 


You can add the proper columns yourself like so:

class AddConfirmableToUsers < ActiveRecord::Migration
  def self.up
    change_table :users do |t|
      t.string :confirmation_token
      t.datetime :confirmed_at
      t.datetime :confirmation_sent_at
    end

    add_index :users, :confirmation_token, :unique => true
  end

  def self.down
    change_table :users do |t|
      t.remove :confirmation_token, :confirmed_at, :confirmation_sent_at
    end

    remove_index :users, :confirmation_token
  end
end


Your migration should work. Did you check your User model to make sure :confirmable is enabled? It's commented out by default.

If you don't mind losing your data you can just do

> rake db:drop

Otherwise you can just edit the initial migration and do a rollback.

# get the current migration version
> rake db:version
> Current version: ****************41
> rake db:rollback ****************40

Make your changes

> rake db:migrate
0

精彩评论

暂无评论...
验证码 换一张
取 消