Support for foreign key constraint in Rails

耗尽温柔 提交于 2019-12-30 00:40:19

问题


In Ruby on Rails, how to add foreign key constraint in migration?


回答1:


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



回答2:


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




回答3:


This is an update to the matthuhiggins-foreigner gem: http://github.com/sparkfly/foreigner

Features:

  • rspec coverage, tested against PostgreSQL 8.3.9 and MySQL 5.0.90
  • Migration support
  • schema.rb support

Future versions will include CHECK constraints for PostgreSQL, which is needed to implement multi-table inheritance.




回答4:


Would it be enough with adding the following, for example with Products and User models?

add_index :products, :user_id



来源:https://stackoverflow.com/questions/320194/support-for-foreign-key-constraint-in-rails

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!