MySQL8.0添加和删除check约束

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约束的操作就这三句。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值