【重学 MySQL】六十七、解锁检查约束,守护数据完整性

【重学 MySQL】六十七、解锁检查约束,守护数据完整性

  • 检查约束的基本概念
  • 检查约束的语法
  • 检查约束的使用场景
  • 注意事项
  • 示例

在这里插入图片描述
在MySQL中,检查约束(CHECK)是一种用于确保表中数据满足特定条件的约束。

检查约束的基本概念

检查约束用于限制表中列的值,以确保它们满足特定的条件。这些条件通常通过SQL表达式来定义,当插入或更新数据时,MySQL会验证这些表达式是否为真。如果表达式为假,则操作会被拒绝,从而保证了数据的完整性和有效性。

检查约束的语法

  1. 在创建表时添加检查约束

    • 语法格式:
      CREATE TABLE 表名 (列名 数据类型 CHECK (条件表达式),...
      );
      
    • 示例:
      CREATE TABLE users (id INT PRIMARY KEY,age INT CHECK (age >= 18)
      );
      

    在这个示例中,age列被添加了一个检查约束,确保age的值大于或等于18。

  2. 在修改表时添加检查约束

    • 语法格式:
      ALTER TABLE 表名 ADD CONSTRAINT 约束名 CHECK (条件表达式);
      
    • 示例:
      ALTER TABLE users ADD CONSTRAINT chk_age CHECK (age < 100);
      

    在这个示例中,向users表添加了一个名为chk_age的检查约束,确保age的值小于100。

  3. 删除检查约束

    • 语法格式:
      ALTER TABLE 表名 DROP CONSTRAINT 约束名;
      
    • 示例:
      ALTER TABLE users DROP CONSTRAINT chk_age;
      

    在这个示例中,从users表中删除了名为chk_age的检查约束。

检查约束的使用场景

检查约束通常用于以下场景:

  1. 限制列的值范围:例如,确保年龄字段的值在合理范围内(如18到100之间)。
  2. 确保数据的有效性:例如,确保电子邮件字段的值符合电子邮件的格式。
  3. 维护数据的一致性:例如,确保两个相关字段之间的值满足特定关系(如一个字段的值必须大于另一个字段的值)。

注意事项

  1. MySQL版本:检查约束在MySQL 8.0.16及更高版本中才得到全面支持。在之前的版本中,虽然可以添加检查约束,但MySQL不会对其进行验证。
  2. 复杂表达式:检查约束可以使用简单的表达式,也可以包含复杂的逻辑和子查询。但是,请注意性能问题,因为复杂的表达式可能会增加数据插入和更新的开销。
  3. 命名规范:为检查约束指定一个有意义的名称是一个好习惯,这有助于在需要时更容易地识别和管理约束。

示例

以下是一个综合示例,展示了如何在创建和修改表时使用检查约束:

-- 创建表时添加检查约束
CREATE TABLE employees (id INT PRIMARY KEY,name VARCHAR(100),salary DECIMAL(10, 2) CHECK (salary > 0),hire_date DATE CHECK (hire_date >= '2000-01-01')
);-- 修改表时添加检查约束
ALTER TABLE employees ADD CONSTRAINT chk_salary_max CHECK (salary <= 100000);-- 尝试插入数据(合法)
INSERT INTO employees (id, name, salary, hire_date) VALUES (1, 'Alice', 50000, '2020-05-15');-- 尝试插入数据(不合法,salary小于0)
INSERT INTO employees (id, name, salary, hire_date) VALUES (2, 'Bob', -1000, '2021-06-20'); -- 会失败-- 尝试插入数据(不合法,hire_date小于2000-01-01)
INSERT INTO employees (id, name, salary, hire_date) VALUES (3, 'Charlie', 60000, '1999-12-31'); -- 会失败

在这个示例中,employees表在创建时添加了两个检查约束:一个确保salary大于0,另一个确保hire_date大于或等于2000-01-01。然后,通过ALTER TABLE语句添加了一个额外的检查约束,确保salary小于或等于100000。最后,尝试插入一些数据来演示检查约束的效果。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/55884.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

考研前所学c语言02(2024/10/16)

1.一个十进制的数转化为二进制的就是不断除二取余&#xff0c;得到的余数从下到上取 比如123&#xff1a; 结果为&#xff1a; 同理其他的十进制转八进制&#xff0c;十六进制就除八&#xff0c;除十六即可 再比如123转十六进制&#xff1a; 因为余数是11&#xff0c;十六进…

【JavaEE初阶】深入理解网络编程—使用UDP协议API实现回显服务器

前言 &#x1f31f;&#x1f31f;本期讲解关于TCP/UDP协议的原理理解~~~ &#x1f308;感兴趣的小伙伴看一看小编主页&#xff1a;GGBondlctrl-CSDN博客 &#x1f525; 你的点赞就是小编不断更新的最大动力 &#x1f386;那么废话不…

从0开始深度学习(12)——多层感知机的逐步实现

依然以Fashion-MNIST图像分类数据集为例&#xff0c;手动实现多层感知机和激活函数的编写&#xff0c;大部分代码均在从0开始深度学习&#xff08;9&#xff09;——softmax回归的逐步实现中实现过 1 读取数据 import torch from torchvision import transforms import torchv…

查找与排序-交换排序

交换排序是基于“比较”和“交换”两种操作来实现的排序方法 。 由于选择“比较”的基准元素不同&#xff0c;可将交换排序分为以下两种&#xff1a; 冒泡排序快速排序 一、冒泡排序 1.冒泡排序基本思想 因为其实现与气泡从水中往上冒的过程类似而得名。 每一趟的…

基于SpringBoot+Vue+uniapp微信小程序的垃圾分类系统的详细设计和实现(源码+lw+部署文档+讲解等)

项目运行截图 技术框架 后端采用SpringBoot框架 Spring Boot 是一个用于快速开发基于 Spring 框架的应用程序的开源框架。它采用约定大于配置的理念&#xff0c;提供了一套默认的配置&#xff0c;让开发者可以更专注于业务逻辑而不是配置文件。Spring Boot 通过自动化配置和约…

Redux (八) 路由React-router、嵌套路由、路由传参、路由懒加载

文章目录 一、React-Router的基本使用1. 安装及基本使用(路由映射配置)2. 路由跳转Link与NavLink3. Navigate导航4. 处理路径不存在的情况 二、嵌套路由三、手动跳转 (类似编程式路由导航)1. 函数式组件2. 类组件实现手动跳转 四、路由传参1. 路径设置占位符(params)2. search传…

Java面试指南:Java基础介绍

这是《Java面试指南》系列的第1篇&#xff0c;本篇主要是介绍Java的一些基础内容&#xff1a; 1、Java语言的起源 2、Java EE、Java SE、Java ME介绍 3、Java语言的特点 4、Java和C的区别和联系&#xff1f; 5、面向对象和面向过程的比较 6、Java面向对象的三大特性&#xff1a…

leetcode30:串联所有单词的字串

给定一个字符串 s 和一个字符串数组 words。 words 中所有字符串 长度相同。 s 中的 串联子串 是指一个包含 words 中所有字符串以任意顺序排列连接起来的子串。 例如&#xff0c;如果 words ["ab","cd","ef"]&#xff0c; 那么 "abcdef…

1. 解读DLT698.45-2017通信规约--预连接响应

国家电网有限公司企业标准&#xff0c;面向对象的用电信息数据交换协议DLT698.45-2017 为提高用电信息采集系统的业务适应性、采集效率、安全性和数据溯源性&#xff0c;规范用电信息数据交换协议的通信架构、数据链路层、应用层、接口类与对象标识&#xff0c;制定本标准。 …

Linux系统:(Linux系统概述与安装)

硬件计算机硬件是指计算机系统中所有物理部件的总称。包括计算机主机、显示器、键盘、鼠标、内存、硬盘、处理器、主板等等。这些硬件部件是计算机系统运行的基础 不管是电脑系统(个人电脑、服务器等)、还是移动端操作系统(手机、平板等)。它的功能就是做为用户和硬件之间的桥梁…

前端求职简历-待补充

当然可以&#xff0c;针对大厂的前端岗位&#xff0c;一个吸引人的简历应该突出你的技术能力、项目经验、教育背景以及任何能体现你学习能力和团队协作能力的证明。以下是一个简历大纲示例&#xff0c;你可以根据自己的实际情况进行调整&#xff1a; 个人信息 姓名联系方式&a…

图文深入介绍oracle资源管理(续)

1. 引言&#xff1a; 本文将承接上篇继续深入介绍oracle资源管理。本文重点介绍如何使用oracle资源管理器管理好DB。 2. 资源管理器&#xff1a; 可以使用图形界面 OEM$或命令行调用 DBMS RESOURCE MANAGER 程序包的过程进行数据库资源管理。 调用资源管理器的先决条件&…

瑞数后缀加密怎么处理

前言&#xff1a; 瑞数我们经常补环境通过&#xff0c;但是遇到瑞数后缀不知道怎么处理 就拿瑞数4来讲 解决方法&#xff1a; &#xff08;1&#xff09;传明文加密参数 一般情况&#xff0c;我们传明文加密参数也能访问 &#xff08;2&#xff09;再补环境基础调用open …

基于stm32的4G模块点灯实验

led模块功能封装 #include "led.h" #include "sys.h"//初始化GPIO函数 void led_init(void) {GPIO_InitTypeDef gpio_initstruct;//打开时钟__HAL_RCC_GPIOB_CLK_ENABLE();//调用GPIO初始化函数gpio_initstruct.Pin GPIO_PIN_8 | GPIO_PIN_9;gpio_inits…

排序算法 —— 直接插入排序

目录 1.直接插入排序的思想 2.直接插入排序的实现 实现分析 实现代码 3.直接插入排序的分析 时间复杂度分析 空间复杂度分析 稳定性 1.直接插入排序的思想 直接插入排序的思想就是把待排序的元素按其关键码值的大小依次插入到一个已经排好序的有序序列中&#xff0c…

pycharm调试带参数命令行的程序

点击 run configuration 点击加号&#xff0c;选择python name填写程序名字&#xff0c;script填写程序路径&#xff0c;下一行填写传入的参数 点击apply&#xff0c;再点ok&#xff0c;即可debug 参考&#xff1a; pycharm 调试模式下命令行参数的传递_pycharm debug传参 ya…

项目实战:构建 effet.js 人脸识别交互系统的实战之路

&#x1f4dd;个人主页&#x1f339;&#xff1a;Eternity._ &#x1f339;&#x1f339;期待您的关注 &#x1f339;&#x1f339; ❀构建 effet.js &#x1f4d2;1. 什么是effet.js&#x1f4dc;2. 为什么需要使用effet.js&#x1f4dd;3. effet.js的功能&#x1f4da;4. 使用…

【项目案例】-音乐播放器-Android前端实现-Java后端实现

精品专题&#xff1a; 01.C语言从不挂科到高绩点 https://blog.csdn.net/yueyehuguang/category_12753294.html?spm1001.2014.3001.5482https://blog.csdn.net/yueyehuguang/category_12753294.html?spm1001.2014.3001.5482 02. SpringBoot详细教程 https://blog.csdn.ne…

HTML之表单设计

1、HTML表单 HTML表单是用于收集用户输入的信息&#xff0c;并将用户输入的内容信息传到后台服务器中。 表单是通过form标签实现。 特别注意&#xff1a;如果一些内容提交后&#xff0c;没有将内容提交给后台服务器&#xff0c;那么需要添加一个name属性&#xff0c;语法&am…

NC 单据模板自定义项 设置参照(自定义参照)

NC 单据模板自定义项 设置参照&#xff08;自定义参照&#xff09; 如图下图&#xff0c;NC 单据模板自定义项 设置参照&#xff1a; 1、选择需要设置参照的自定义字段&#xff0c;选择高级属性页签&#xff0c;在类型设置中&#xff0c;数据类型选择参照信息&#xff0c;即bd…