MySQL使用check约束的方法:1、如果要设置CHECK约束的字段范围小,并且比较容易列举全部的值,可以将该字段的类型设置为enum类型或set类型。2、如果需要设置CHECK约束的字段范围大,且列举全部值比较困难,使用触发器来代替约束实现数据的有效性了。

在一些情况下,我们需要字段在指定范围的输入,
例如:性别只能输入 ‘男’或者’女’,余额只能大于0等条件,
例如:可以要求 authors 表的 postcode 列只允许输入六位数字的邮政编码。
我们除了在程序上控制以外,我们还能使用 CHECK 约束 来规范数据。
然而:
mysql所有的存储引擎均不支持check约束,MySQL会对check子句进行分析,但是在插入数据时会忽略,因此check并不起作用。
解决这个问题的两种方式:
1、如果要设置CHECK约束的字段范围小,并且比较容易列举全部的值,就可以考虑将该字段的类型设置为枚举类型 enum()或集合类型set()。
AppMall应用商店
AI应用商店,提供即时交付、按需付费的人工智能应用服务
56 查看详情
比如性别字段可以这样设置,插入枚举值以外值的操作将不被允许。
CREATE TABLE `Student` ( `Sno` char(8) NOT NULL, `Sname` varchar(10) NOT NULL, `Sex` enum('男','女') NOT NULL DEFAULT '男', `Age` tinyint(4) NOT NULL DEFAULT '20', `Phonenumber` char(12) DEFAULT NULL, `Sdept` varchar(20) NOT NULL, PRIMARY KEY (`Sno`), UNIQUE KEY `Phonenumber` (`Phonenumber`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;
2、如果需要设置CHECK约束的字段范围大,且列举全部值比较困难,比如整数或者某一区间,那就只能使用触发器来代替约束实现数据的有效性了。
DELIMITER $create trigger studentcheck before insert on Student for each rowbeginif new.Age30 then set new.Age=20;end if;end $DELIMITER ;
测试:
mysql> insert into Student(Sno,Sname,Sex,Age,Phonenumber,Sdept) values('5','Joe','m',0,'12345243912','CS');ERROR 1265 (01000): Data truncated for column 'Sex' at row 1mysql> insert into Student(Sno,Sname,Sex,Age,Phonenumber,Sdept) values('5','Joe','男',0,'12345243912','CS');Query OK, 1 row affected (0.00 sec)mysql> select * from Student;+-----+-------+-----+-----+-------------+-------+| Sno | Sname | Sex | Age | Phonenumber | Sdept |+-----+-------+-----+-----+-------------+-------+| 4 | nancy | m | 0 | 12345243965 | CS || 5 | Joe | 男 | 20 | 12345243912 | CS |+-----+-------+-----+-----+-------------+-------+2 rows in set (0.00 sec)
可以看出,现在Sex必须在“男”和“女”中选择,否则插入失败;当年龄不合规范时,由于触发器的存在,会将其自动设置为默认的20。
由此可以解决check约束无效的问题。
以上就是MySQL怎么使用check约束的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/372372.html
微信扫一扫
支付宝扫一扫