mysql的check约束怎么设置_MySQL怎么使用check约束

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

c9502994a184dc825b6b0d7990f4f6c0.png

在一些情况下,我们需要字段在指定范围的输入,

例如:性别只能输入 '男'或者'女',余额只能大于0等条件,

例如:可以要求 authors 表的 postcode 列只允许输入六位数字的邮政编码。

我们除了在程序上控制以外,我们还能使用 CHECK 约束 来规范数据。

然而:

mysql所有的存储引擎均不支持check约束,MySQL会对check子句进行分析,但是在插入数据时会忽略,因此check并不起作用。

解决这个问题的两种方式:

1、如果要设置CHECK约束的字段范围小,并且比较容易列举全部的值,就可以考虑将该字段的类型设置为枚举类型 enum()或集合类型set()。

比如性别字段可以这样设置,插入枚举值以外值的操作将不被允许。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 row

begin

if new.Age<15 or new.Age>30 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 1

mysql> 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约束无效的问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值