在使用MySQL的检查(check)约束时,向表中插入不符合约束条件的数据行时,也能插入成功不会报错!
建表语句如下:
create table person
(
person_id int unsigned,
fname varchar(16),
lname varchar(16),
gender char(1) check(gender in ('M','F')),
birth_date date,
constraint pk_test_person primary key (person_id)
);
向其中插入行
INSERT INTO `person` (`person_id`, `fname`, `lname`, `gender`, `birth_date`)
VALUES (1, 'Zhang', 'San', 'a', '2019-03-28')
居然返回
1 row affected in 10 ms
看来check约束是白写了,没有起作用.
经过上网查看发现,MySQL只是可以使用check约束,但不会强制的遵循check约束!
官方推荐使用枚举类型(ENUM)来替代以上的使用check约束的情况.将表中的gender字段修改成如下类型:
(注意修改前的表中数据不能有gender字段含有不是'M'或'F'的数据行,否则不能执行以下语句,会报错)
ALTER TABLE person MODIFY gender enum('M', 'F');
执行alter语句后的person表的gender就会在插入和修改时严格验证属于的数据是否合法啦!
测试一下:
如下插入语句会报错
insert into person (person_id, fname, lname, gender, birth_date)
values (1,'Zhang','San','X','2019-03-28');
当输入正确的语句时不会报错,通过验证
insert into person (person_id, fname, lname, gender, birth_date)
values (1,'Zhang','San','M','2019-03-28');