MySql -- check 约束

6.CHECK 约束:用于限制列中的值的范围

在一些情况下,我们需要字段在指定范围的输入,
例如:性别只能输入 \'男\'或者\'女\',余额只能大于0等条件,
我们除了在程序上控制以外,我们还能使用 CHECK 约束 来规范数据。

然而:
mysql所有的存储引擎均不支持check约束,MySQL会对check子句进行分析,但是在插入数据时会忽略,因此check并不起作用,因此实现对数据约束有两种方法:
1.在mysql种约束,如使用enum类型或者触发器等。
2.在应用程序里面对数据进行检查再插入。

使用 ENUM 限制插入的值,但是这种方式只能用于离散型数据,对于范围数据则无能为力

-- 创建一张测试表,规定sex字段只能是 ‘男’ 或者 ‘女’ CREATE TABLE `user` ( `id` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT, `name` VARCHAR(18) COLLATE utf8_estonian_ci NOT NULL, `sex` ENUM(\'\',\'\') COLLATE utf8_estonian_ci DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=INNODB DEFAULT CHARSET=utf8 COLLATE=utf8_estonian_ci

测试:
INSERT INTO `user`(`name`,`sex`) VALUES(\'秀吉\',\'秀吉\');

结果:
错误代码: 1265
Data truncated for column \'sex\' at row 1

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/zgyxsg.html