百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> MySQL怎么运用check束缚
分享文章到:

MySQL怎么运用check束缚

发布时间:08/01 来源:未知 浏览: 关键词:
mysql所有的存储引擎均不支撑check束缚,因而实现对数据束缚有两种办法:1.在mysql种束缚,如运用enum类型或者触发器等。2.在利用程序里面临数据进行检查再插入。 在数据库中,CHECK 束缚是指束缚表中某一个或者某些列中可承受的数据值或者数据格局(用于限定列中的值的范畴)。

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

要是我们需要限定范畴内数据,例如:余额只能大于100这样的前提,我们可以运用触发器来实现。

DELIMITER $$
CREATE
    TRIGGER `test`.`remaining_BeforeInsert` BEFORE INSERT ON `test`.`user`
    FOR EACH ROW BEGIN
    IF `user`.`remaining` < 100 THEN  
        SET `user`.`remaining` = 100;  
    END IF;  
    END$$
DELIMITER ;

以上就是MySQL怎么运用check束缚的细致内容,更多请关注 百分百源码网 其它相干文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有151人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板