参考或删除时的级联删除选项
Option for Cascade Delete for References or On Delete
在 Rails 4.2 中,当创建 table 或通过引用添加引用或 add_reference 如何指定外键应在删除时级联。
生成脚手架的命令:
rails g scaffold Child parent:references name:string
产生的迁移:
create_table :childs do |t|
t.references :parent, index: true, foreign_key: true
t.string :name
t.timestamps null: false
end
这应该有效
create_table :childs do |t|
t.references :parent, index: true, foreign_key: {on_delete: :cascade}
t.string :name
t.timestamps null: false
end
根据ActiveRecord::ConnectionAdapters::TableDefinition#references
,如果在foreign_key
选项上指定了哈希值,它会直接传递给foreign_key
方法。
来源:
foreign_key(col.to_s.pluralize, foreign_key_options.is_a?(Hash) ? foreign_key_options : {}) if foreign_key_options
另请注意,如果您已经设置了 table,则可以通过执行以下操作生成迁移以更新 foreign_key:
def up
remove_foreign_key :children, :parent
add_foreign_key :children, :parent, on_delete: :cascade
end
def down
remove_foreign_key :children, :parent
add_foreign_key :children, :parent
end
在 Rails 4.2 中,当创建 table 或通过引用添加引用或 add_reference 如何指定外键应在删除时级联。
生成脚手架的命令:
rails g scaffold Child parent:references name:string
产生的迁移:
create_table :childs do |t|
t.references :parent, index: true, foreign_key: true
t.string :name
t.timestamps null: false
end
这应该有效
create_table :childs do |t|
t.references :parent, index: true, foreign_key: {on_delete: :cascade}
t.string :name
t.timestamps null: false
end
根据ActiveRecord::ConnectionAdapters::TableDefinition#references
,如果在foreign_key
选项上指定了哈希值,它会直接传递给foreign_key
方法。
来源:
foreign_key(col.to_s.pluralize, foreign_key_options.is_a?(Hash) ? foreign_key_options : {}) if foreign_key_options
另请注意,如果您已经设置了 table,则可以通过执行以下操作生成迁移以更新 foreign_key:
def up
remove_foreign_key :children, :parent
add_foreign_key :children, :parent, on_delete: :cascade
end
def down
remove_foreign_key :children, :parent
add_foreign_key :children, :parent
end