mysql 约束不起作用,MySQL中的CHECK约束不起作用

不幸的是,MySQL不支持SQL检查约束。 你可以在你的DDL查询中定义它们的兼容性,但是它们只是被忽略。

有一个简单的select

您可以创buildBEFORE INSERT和BEFORE UPDATE触发器,这些触发器可能会导致错误,或者在不满足数据需求时将字段设置为默认值。

BEFORE INSERT在MySQL 5.5之后工作的例子

DELIMITER $$ CREATE TRIGGER `test_before_insert` BEFORE INSERT ON `Test` FOR EACH ROW BEGIN IF CHAR_LENGTH( NEW.ID ) < 4 THEN SIGNAL SQLSTATE '12345' SET MESSAGE_TEXT := 'check constraint on Test.ID failed'; END IF; END$$ DELIMITER ;

在MySQL 5.5之前,你必须导致一个错误,例如调用一个未定义的过程。

在这两种情况下,这会导致隐式事务回滚。 MySQL不允许在过程和触发器中使用ROLLBACK语句。

如果你不想回滚事务(即使失败的“检查约束”,INSERT / UPDATE也应该通过),你可以使用SET NEW.ID = NULL覆盖这个值,这会将id设置为字段默认值,不会真的有意义的一个ID寿

编辑:删除了stream浪的报价。

关于:=运算符:

与=不同, :=运算符永远不会被解释为比较运算符。 这意味着您可以在任何有效的SQL语句(不仅仅是在SET语句中)中使用:=为variables赋值。

关于反引号标识符的引用:

标识符引号字符是反引号(“`”)

如果启用了ANSI_QUOTES SQL模式,则也可以在双引号内引用标识符

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值