加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

MySQL节制束缚

发布时间:2021-05-18 03:27:59 所属栏目:编程 来源:互联网
导读:若将 CHECK 束缚子句置于表中某个列的界说之后,则这种束缚也称为基于列的 CHECK 束缚。 在更新表数据的时辰,体系会搜查更新后的数据行是否满意 CHECK 束缚中的
若将 CHECK 束缚子句置于表中某个列的界说之后,则这种束缚也称为基于列的 CHECK 束缚。

在更新表数据的时辰,体系会搜查更新后的数据行是否满意 CHECK 束缚中的限制前提。MySQL 可以行使简朴的表达式来实现 CHECK 束缚,也应承行使伟大的表达式作为限制前提,譬喻在限制前提中插手子查询。

留意:若将 CHECK 束缚子句置于全部列的界说以及主键束缚和外键界说之后,则这种束缚也称为基于表的 CHECK 束缚。该束缚可以同时对表中多个列配置限制前提。

在建设表时配置搜查束缚 一样平常环境下,假如体系的表布局已经计划完成,那么在建设表时就可觉得字段配置搜查束缚了。

建设表时配置搜查束缚的语法名目如下:

CHECK(<搜查束缚>)

例 1 在 test_db 数据库中建设 tb_emp7 数据表,要求 salary 字段值大于 0 且小于 10000,SQL 语句和运行功效如下所示。 mysql> CREATE TABLE tb_emp7 -> ( -> id INT(11) PRIMARY KEY, -> name VARCHAR(25), -> deptId INT(11), -> salary FLOAT, -> CHECK(salary>0 AND salary<100), -> FOREIGN KEY(deptId) REFERENCES tb_dept1(id) -> ); Query OK, 0 rows affected (0.37 sec) 在修改表时添加搜查束缚 假如一个表建设完成,可以通过修改表的方法为表添加搜查束缚。

修改表时配置搜查束缚的语法名目如下:

ALTER TABLE tb_emp7 ADD CONSTRAINT <搜查束缚名> CHECK(<搜查束缚>)

例 2 修改 tb_emp7 数据表,要求 id 字段值大于 0,SQL 语句和运行功效如下所示。 mysql> ALTER TABLE tb_emp7 -> ADD CONSTRAINT check_id -> CHECK(id>0); Query OK, 0 rows affected (0.19 sec) Records: 0 Duplicates: 0 Warnings: 0 删除搜查束缚 修改表时删除搜查束缚的语法名目如下:

ALTER TABLE <数据表名> DROP CONSTRAINT <搜查束缚名>;

例 3 删除 tb_emp7 表中的 check_id 搜查束缚,SQL 语句和运行功效如下所示: mysql> ALTER TABLE tb_emp7 -> DROP CONSTRAINT check_id; Query OK, 0 rows affected (0.19 sec) Records: 0 Duplicates: 0 Warnings: 0

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读