MySQL8.0添加和删除check约束

MySQL8.0中,添加了对check约束的操作,我使用的MySQL版本是8.0.17.0,下面我使用navicat for MySQL来演示。

check约束作用效果

使用show create table来查看创建表的语句

| testtable | CREATE TABLE `testtable` (
 	 `ID` varchar(5) NOT NULL,
	  `name` varchar(20) NOT NULL,
	  `dept_name` varchar(20) DEFAULT NULL,
	  `salary` decimal(8,2) DEFAULT NULL,
	  PRIMARY KEY (`ID`),
	  KEY `dept_name` (`dept_name`),
	  CONSTRAINT `testtable_ibfk_1` FOREIGN KEY (`dept_name`) REFERENCES `department` (`dept_name`) ON DELETE SET NULL,
	  CONSTRAINT `testtable_chk_1` CHECK ((`salary` > 29000))
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |

这里对属性salary添加check约束,规定salary>29000
检查check约束是否起作用

mysql> INSERT INTO testtable
    -> (ID,name,dept_name,salary)
    -> VALUES
    -> ('00000','name','Biology','10000');
3819 - Check constraint 'testtable_chk_1' is violated.

发现check约束是能起作用的

添加check约束

ALTER TABLE `表名` ADD CONSTRAINT [约束名] CHECK(约束条件) [[NOT] ENFORCED];

[ ]表示可填可不填,不填约束名的话,MySQL会自动生成约束名
ENFORCED表示是否强制,默认是强制的,即会对改变的数据进行约束,NOT ENFORCED表示check约束不作用。

mysql> ALTER TABLE `testtable` ADD CONSTRAINT testtable_chk_1 CHECK(salary>29000);
Query OK, 0 rows affected
Records: 0  Duplicates: 0  Warnings: 0

删除check约束

ALTER TABLE `表名` DROP CHECK 约束名;
mysql> ALTER TABLE `testtable` DROP CHECK testtable_chk_1;
Query OK, 0 rows affected
Records: 0  Duplicates: 0  Warnings: 0

修改check约束的强制性

ALTER TABLE `表名` ALTER CHECK 约束名 [NOT] ENFORCED;
mysql> ALTER TABLE `testtable` ALTER CHECK testtable_chk_1 NOT ENFORCED;
Query OK, 0 rows affected
Records: 0  Duplicates: 0  Warnings: 0

目前所知MySQL对check约束的操作就这三句。

### MySQL 8.0 创建表语法及示例 在 MySQL 8.0 中,创建表的核心操作通过 `CREATE TABLE` 语句完成。以下是关于该语句的详细介绍以及一些实际使用的例子。 #### 基础语法 `CREATE TABLE` 的基本结构如下: ```sql CREATE TABLE table_name ( column1 datatype constraints, column2 datatype constraints, ... ); ``` 其中: - **table_name**: 表名。 - **columnN**: 列名称。 - **datatype**: 数据类型(如 INT、VARCHAR、DATE 等)。 - **constraints**: 可选约束条件(如 PRIMARY KEY、NOT NULL、UNIQUE 等)[^4]。 #### 实际案例 下面是一些具体的实例来展示如何创建不同类型的表。 ##### 示例 1:简单的学生信息表 假设我们需要存储学生的姓名年龄,则可以这样定义表格: ```sql CREATE TABLE students ( id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(50) NOT NULL, age INT CHECK (age >= 0 AND age <= 150), created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ); ``` 此脚本中包含了自增主键 (`AUTO_INCREMENT`)、字符串字段 (`VARCHAR`)、整数字段 (`INT`) 时间戳默认值设置 (^4])。 ##### 示例 2:带有外键关系的学校与学生关联表 如果要建立两个实体之间的联系——比如一所学校的多个学生记录,可以通过 FOREIGN KEY 来实现这种参照完整性控制: ```sql -- 首先创建 schools 表 CREATE TABLE schools ( school_id INT AUTO_INCREMENT PRIMARY KEY, school_name VARCHAR(100) UNIQUE NOT NULL ); -- 接着创建 students 表,并指定 foreign key 关联到 schools 表上 CREATE TABLE students ( student_id INT AUTO_INCREMENT PRIMARY KEY, first_name VARCHAR(50), last_name VARCHAR(50), school_id INT, CONSTRAINT fk_school FOREIGN KEY(school_id) REFERENCES schools(school_id) ON DELETE CASCADE -- 当删除某个school时自动清除其对应students数据 ); ``` 上述SQL片段展示了如何利用FOREIGN KEYS构建多对一的关系模型[^5]. #### 使用窗口函数扩展功能 除了基础的数据管理之外,在较新的版本里还可以结合窗体函数(Window Functions),它们允许我们在查询结果集中执行复杂的计算而无需子查询或者临时表的帮助。例如统计每所学校内的学生数量排名情况就可以采用ROW_NUMBER() OVER(...)形式表达出来[^2]: ```sql WITH ranked_students AS( SELECT s.student_id, sc.school_id, COUNT(*) over(PARTITION BY sc.school_id ORDER BY s.age ASC ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW ) rank_num FROM students s JOIN schools sc USING(school_id)) SELECT * FROM ranked_students WHERE rank_num<=3; ``` 以上就是有关于MySQL 8.0下创建表的一些基础知识介绍及其应用举例说明.
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值