2016-05-27 16:13:36 +00:00
|
|
|
.. _check_dialog:
|
|
|
|
|
2018-06-15 08:14:12 +00:00
|
|
|
*********************
|
|
|
|
`Check Dialog`:index:
|
|
|
|
*********************
|
2016-05-27 16:13:36 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
Use the *Check* dialog to define or modify a check constraint. A check
|
|
|
|
constraint specifies an expression that produces a Boolean result that new or
|
|
|
|
updated rows must satisfy for an insert or update operation to succeed.
|
2016-05-27 16:13:36 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
The *Check* dialog organizes the development of a check constraint through the
|
|
|
|
*General* and *Definition* tabs. The *SQL* tab displays the SQL code generated
|
|
|
|
by dialog selections.
|
2016-05-27 16:13:36 +00:00
|
|
|
|
|
|
|
.. image:: images/check_general.png
|
2018-01-11 16:58:30 +00:00
|
|
|
:alt: Check dialog general tab
|
2019-03-08 15:29:05 +00:00
|
|
|
:align: center
|
2016-05-27 16:13:36 +00:00
|
|
|
|
|
|
|
Use the fields in the *General* tab to identify the check constraint:
|
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
* Use the *Name* field to provide a descriptive name for the check constraint
|
|
|
|
that will be displayed in the *pgAdmin* tree control. With PostgreSQL 9.5
|
|
|
|
forward, when a table has multiple check constraints, they will be tested for
|
|
|
|
each row in alphabetical order by name and after NOT NULL constraints.
|
2018-01-11 16:58:30 +00:00
|
|
|
* Store notes about the check constraint in the *Comment* field.
|
2016-05-27 16:13:36 +00:00
|
|
|
|
|
|
|
Click the *Definition* tab to continue.
|
|
|
|
|
|
|
|
.. image:: images/check_definition.png
|
2018-01-11 16:58:30 +00:00
|
|
|
:alt: Check dialog definition tab
|
2019-03-08 15:29:05 +00:00
|
|
|
:align: center
|
2016-05-27 16:13:36 +00:00
|
|
|
|
|
|
|
Use the fields in the *Definition* tab to define the check constraint:
|
|
|
|
|
|
|
|
* Provide the expression that a row must satisfy in the *Check* field.
|
2019-05-21 10:51:19 +00:00
|
|
|
* Move the *No Inherit?* switch to the *Yes* position to specify that this
|
|
|
|
constraint is not automatically inherited by a table's children. The default
|
|
|
|
is *No*, meaning that the constraint will be inherited by any children.
|
2019-03-08 15:29:05 +00:00
|
|
|
* Move the *Don't validate?* switch to the *No* position to skip validation of
|
|
|
|
existing data; the constraint may not hold for all rows in the table. The
|
|
|
|
default is *Yes*.
|
2016-05-27 16:13:36 +00:00
|
|
|
|
|
|
|
Click the *SQL* tab to continue.
|
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
Your entries in the *Check* dialog generate a SQL command (see an example
|
|
|
|
below). Use the *SQL* tab for review; revisit or switch tabs to make any changes
|
|
|
|
to the SQL command.
|
2016-05-27 16:13:36 +00:00
|
|
|
|
|
|
|
**Example**
|
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
The following is an example of the sql command generated by user selections in
|
|
|
|
the *Check* dialog:
|
2016-05-27 16:13:36 +00:00
|
|
|
|
|
|
|
.. image:: images/check_sql.png
|
2018-01-11 16:58:30 +00:00
|
|
|
:alt: Check dialog sql tab
|
2019-03-08 15:29:05 +00:00
|
|
|
:align: center
|
2016-05-27 16:13:36 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
The example shown demonstrates creating a check constraint named *check_price*
|
|
|
|
on the *price* column of the *products* table. The constraint confirms that
|
|
|
|
any values added to the column are greater than 0.
|
2016-05-27 16:13:36 +00:00
|
|
|
|
2018-01-11 16:58:30 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
* Click the *Info* button (i) to access online help.
|
2016-05-27 16:13:36 +00:00
|
|
|
* Click the *Save* button to save work.
|
|
|
|
* Click the *Cancel* button to exit without saving work.
|
2016-06-21 08:06:44 +00:00
|
|
|
* Click the *Reset* button to restore configuration parameters.
|