Add A Check Constraint To A Table
PostgreSQL allows you to enforce all kinds of rules about the value of a column or the relationship between two columns. These rules are defined with check constraints. ActiveRecord's migration DSL does not provide a way for adding check constraints directly. They can be added by executing a SQL statement in a migration.
This check constraint ensures that, anytime you add or update a row in the book column, the value of page_count
column is always greater than 0
. This is a nice thing to enforce because it wouldn't make much sense for a book to have, say, -10
pages.
Note: these constraints will not appear in your db/schema.rb
file. If you want to see what check constraints have been defined across your tables, you can crack open psql
to investigate.
Last updated