我无法了解迁移如何根据模型自行更新。
例如,我设计了设置,我想删除电子邮件字段,只有一个用户名和密码字段。
所以,我做了
class User < ActiveRecord::Base
# Include default devise modules. Others available are:
# :token_authenticatable, :confirmable,
# :lockable, :timeoutable and :omniauthable
devise :database_authenticatable, :rememberable, :trackable, :validatable
# Setup accessible (or protected) attributes for your model
attr_accessible :username, :password
# attr_accessible :title, :body
end
但是,即使在
之后,迁移文件也不会反映这些更改rake db:migrate
或
rake db:reset
迁移文件仍有电子邮件字段
class DeviseCreateUsers < ActiveRecord::Migration
def change
create_table(:users) do |t|
## Database authenticatable
t.string :email, :null => false, :default => ""
t.string :encrypted_password, :null => false, :default => ""
## Recoverable
t.string :reset_password_token
t.datetime :reset_password_sent_at
## Rememberable
t.datetime :remember_created_at
## Trackable
t.integer :sign_in_count, :default => 0
t.datetime :current_sign_in_at
t.datetime :last_sign_in_at
t.string :current_sign_in_ip
t.string :last_sign_in_ip
## Confirmable
# t.string :confirmation_token
# t.datetime :confirmed_at
# t.datetime :confirmation_sent_at
# t.string :unconfirmed_email # Only if using reconfirmable
## Lockable
# t.integer :failed_attempts, :default => 0 # Only if lock strategy is :failed_attempts
# t.string :unlock_token # Only if unlock strategy is :email or :both
# t.datetime :locked_at
## Token authenticatable
# t.string :authentication_token
t.timestamps
end
add_index :users, :email, :unique => true
add_index :users, :reset_password_token, :unique => true
# add_index :users, :confirmation_token, :unique => true
# add_index :users, :unlock_token, :unique => true
# add_index :users, :authentication_token, :unique => true
end
end
我也尝试删除迁移文件,以便Rails希望知道创建一个新文件。但是,这不起作用,迁移仍然从某个地方运行?这些迁移在哪里运行?请注意,我的db / migrate文件当时是空的。
-- create_table("users", {:force=>true})
-> 0.2476s
-- add_index("users", ["email"], {:unique=>true, :name=>"index_users_on_email"})
-> 0.1832s
-- add_index("users", ["reset_password_token"], {:unique=>true, :name=>"index_users_on_reset_password_token"})
-> 0.1832s
-- initialize_schema_migrations_table()
-> 0.3776s
-- assume_migrated_upto_version(20130320033132, ["/home/Portfolio Rails/portfolio/db/migrate"])
-> 0.1532s
答案 0 :(得分:1)
你已经倒退了。迁移是磁盘上的文件。他们从不“更新自己”,虽然您可以要求Rails为您生成它们,但它是根据您的输入而不是数据库或模型的状态来执行此操作。
更改不会从模型流向迁移,而是通过数据库从迁移流向模型。 您,开发人员,负责通过引入新迁移来导致对数据库的更改。如果要删除字段,则需要创建一个删除该列的新迁移。
运行rake db:migrate
与您的想法相反。它会从迁移中复制状态,而不是到它们。它将查看db/migrate
并查看是否有任何新文件包含有关如何修改数据库状态的说明。
答案 1 :(得分:1)
迁移文件只是您对架构所做修改的文章记录。修改它们对数据库本身没有任何作用。
您需要创建一个删除电子邮件字段的迁移:
rails generate migration remove_email_from_users email:string
rake db:migrate