在MySQL8.0中,添加了对check约束的操作,我使用的MySQL版本是8.0.17.0,下面我使用navicat for MySQL来演示。
check约束作用效果
使用show create table来查看创建表的语句
| testtable | CREATE TABLE `testtable` (
`ID` varchar(5) NOT NULL,
`name` varchar(20) NOT NULL,
`dept_name` varchar(20) DEFAULT NULL,
`salary` decimal(8,2) DEFAULT NULL,
PRIMARY KEY (`ID`),
KEY `dept_name` (`dept_name`),
CONSTRAINT `testtable_ibfk_1` FOREIGN KEY (`dept_name`) REFERENCES `department` (`dept_name`) ON DELETE SET NULL,
CONSTRAINT `testtable_chk_1` CHECK ((`salary` > 29000))
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
这里对属性salary添加check约束,规定salary>29000
检查check约束是否起作用
mysql> INSERT INTO testtable
-> (ID,name,dept_name,salary)
-> VALUES
-> ('00000','name','Biology','10000');
3819 - Check constraint 'testtable_chk_1' is violated.
发现check约束是能起作用的
添加check约束
ALTER TABLE `表名` ADD CONSTRAINT [约束名] CHECK(约束条件) [[NOT] ENFORCED];
[ ]表示可填可不填,不填约束名的话,MySQL会自动生成约束名
ENFORCED表示是否强制,默认是强制的,即会对改变的数据进行约束,NOT ENFORCED表示check约束不作用。
mysql> ALTER TABLE `testtable` ADD CONSTRAINT testtable_chk_1 CHECK(salary>29000);
Query OK, 0 rows affected
Records: 0 Duplicates: 0 Warnings: 0
删除check约束
ALTER TABLE `表名` DROP CHECK 约束名;
mysql> ALTER TABLE `testtable` DROP CHECK testtable_chk_1;
Query OK, 0 rows affected
Records: 0 Duplicates: 0 Warnings: 0
修改check约束的强制性
ALTER TABLE `表名` ALTER CHECK 约束名 [NOT] ENFORCED;
mysql> ALTER TABLE `testtable` ALTER CHECK testtable_chk_1 NOT ENFORCED;
Query OK, 0 rows affected
Records: 0 Duplicates: 0 Warnings: 0
目前所知MySQL对check约束的操作就这三句。