Reputation: 1809
In Ruby on Rails, how to add foreign key constraint in migration?
Upvotes: 9
Views: 8761
Reputation: 4544
AFAIK, there isn't any built-in support for that, but there are several plugins that help you with that. You can also add them manually to your migration files, just use the execute method for that, e.g. (sample from Rails API):
class MakeJoinUnique < ActiveRecord::Migration
def self.up
execute "ALTER TABLE `pages_linked_pages` ADD UNIQUE `page_id_linked_page_id` (`page_id`,`linked_page_id`)"
end
def self.down
execute "ALTER TABLE `pages_linked_pages` DROP INDEX `page_id_linked_page_id`"
end
end
Upvotes: 2
Reputation: 11975
Would it be enough with adding the following, for example with Products
and User
models?
add_index :products, :user_id
Upvotes: 0
Reputation: 1327
This is an update to the matthuhiggins-foreigner gem: http://github.com/sparkfly/foreigner
Features:
Future versions will include CHECK constraints for PostgreSQL, which is needed to implement multi-table inheritance.
Upvotes: 4
Reputation: 933
Here's a gem-based solution that includes support for adding and removing foreign key constraints, doesn't fail with sqlite, and works correctly with schema.rb files:
http://github.com/matthuhiggins/foreigner
Upvotes: 14