data:image/s3,"s3://crabby-images/5cd11/5cd1180264c0eca0804f50b77f2124805c731ba0" alt="Postgresql add foreign key to existing table"
data:image/s3,"s3://crabby-images/f2593/f2593592bb38d65b9508290d06f18264759917e2" alt="postgresql add foreign key to existing table postgresql add foreign key to existing table"
So if that spec fails, don't add the column to The spec spec/db/schema_spec.rb will test if all columns with the _id suffix Reference an ID on a third party platform the _xid suffix is recommended. Only use this suffix for associations between two tables.
data:image/s3,"s3://crabby-images/c85ad/c85ad9265d3962e1955ddabaa8d744e3779f740f" alt="postgresql add foreign key to existing table postgresql add foreign key to existing table"
Naming foreign keysīy default Ruby on Rails uses the _id suffix for foreign keys. Not doing so will result in cascadingĭeletes being very slow. Thus you must also add a concurrent index. When adding a foreign key in PostgreSQL the column is not indexed automatically, Cascading DeletesĮvery foreign key must define an ON DELETE clause, and in 99% of the cases SeeĪdding foreign key constraint to an existing column. The method add_concurrent_foreign_keyĭoes not take care of this so you'll need to do so manually. Keep in mind that you can only safely add foreign keys to existing tables after Adding Foreign Keys In Migrationsįoreign keys can be added concurrently using add_concurrent_foreign_key asĭefined in Gitlab::Database::MigrationHelpers. User), instead of Rails having to do this. The database can very quickly remove associated data (for example, when removing a That data consistency is enforced on database level. Here you will need to add a foreign key on column er_id. ForĮxample, say you have the following model: class User < ActiveRecord :: Base has_many :posts end When adding an association to a model you must also add a foreign key.
data:image/s3,"s3://crabby-images/5cd11/5cd1180264c0eca0804f50b77f2124805c731ba0" alt="Postgresql add foreign key to existing table"