当前位置: 首页 > news >正文

mysql学习教程,从入门到精通,SQL 约束(Constraints)(41)

在数据库设计中,约束(Constraints)用于确保数据的准确性和完整性。它们通过限制可以插入到数据库表中的数据类型来防止无效数据。SQL 中有几种常见的约束类型,包括主键约束(Primary Key)、外键约束(Foreign Key)、唯一约束(Unique)、非空约束(NOT NULL)和检查约束(CHECK)。下面是一篇关于 SQL 约束的详细介绍:

1、SQL 约束(Constraints)

在关系型数据库中,约束是维护数据完整性和一致性的重要机制。约束可以应用于数据库表中的列或表本身,确保数据在插入、更新或删除时满足特定的规则。本文将介绍几种常见的 SQL 约束类型及其用法。

1.1. 主键约束(Primary Key)

主键约束用于唯一标识表中的每一行。主键列不能包含 NULL 值,并且表中的每一行都必须有唯一的主键值。主键可以由一列或多列组成(复合主键)。

CREATE TABLE Students (StudentID INT PRIMARY KEY,FirstName VARCHAR(50),LastName VARCHAR(50),DateOfBirth DATE
);

在上面的例子中,StudentID 列被定义为主键。

1.2. 外键约束(Foreign Key)

外键约束用于在两个表之间建立连接,确保表中的数据具有参照完整性。外键列中的每个值都必须在被引用的表的主键或唯一键中存在。

CREATE TABLE Courses (CourseID INT PRIMARY KEY,CourseName VARCHAR(100)
);CREATE TABLE Enrollments (EnrollmentID INT PRIMARY KEY,StudentID INT,CourseID INT,FOREIGN KEY (CourseID) REFERENCES Courses(CourseID)
);

在这个例子中,Enrollments 表中的 CourseID 列是外键,它引用了 Courses 表中的 CourseID 列。

1.3. 唯一约束(Unique)

唯一约束确保表中的一列或多列的值是唯一的。与主键不同,唯一约束允许 NULL 值,但每个 NULL 值也被视为不同的值。

CREATE TABLE Users (UserID INT PRIMARY KEY,Email VARCHAR(100) UNIQUE,Username VARCHAR(50)
);

在这个例子中,Email 列被定义为唯一约束,确保每个电子邮件地址在表中是唯一的。

1.4. 非空约束(NOT NULL)

非空约束确保列不能包含 NULL 值。它用于确保数据列的完整性,防止遗漏关键信息。

CREATE TABLE Products (ProductID INT PRIMARY KEY,ProductName VARCHAR(100) NOT NULL,Price DECIMAL(10, 2) NOT NULL
);

在这个例子中,ProductNamePrice 列被定义为非空约束,确保在插入新记录时这些列必须有值。

1.5. 检查约束(CHECK)

检查约束用于确保列中的值满足特定的条件。它允许定义更复杂的规则,以确保数据的有效性。

CREATE TABLE Orders (OrderID INT PRIMARY KEY,OrderDate DATE,Status VARCHAR(20),CHECK (Status IN ('Pending', 'Shipped', 'Delivered', 'Cancelled'))
);

在这个例子中,Status 列被定义为检查约束,确保列中的值只能是 'Pending''Shipped''Delivered''Cancelled' 中的一个。

1.6.结论

SQL 约束是确保数据库数据完整性和一致性的关键工具。通过合理应用主键、外键、唯一、非空和检查约束,可以显著提高数据的质量,防止无效数据的插入。了解和应用这些约束对于设计高效、可靠的数据库系统至关重要。


当然,下面我将提供一个具体的 SQL 约束的例子,这个例子将涵盖几种常见的约束类型,并展示如何在创建表时应用它们。

SQL 约束例子

假设我们正在设计一个简单的学生成绩管理系统,其中包含两个表:Students(学生表)和 Grades(成绩表)。

1. 创建 Students

首先,我们创建 Students 表,其中包含学生的基本信息。我们将应用主键约束、唯一约束和非空约束。

CREATE TABLE Students (StudentID INT PRIMARY KEY,        -- 主键约束,确保每个学生有一个唯一的IDFirstName VARCHAR(50) NOT NULL,   -- 非空约束,确保名字不为空LastName VARCHAR(50) NOT NULL,    -- 非空约束,确保姓氏不为空Email VARCHAR(100) UNIQUE,        -- 唯一约束,确保每个电子邮件地址是唯一的DateOfBirth DATE                 -- 日期字段,无约束(可以为空)
);
2. 创建 Grades

接下来,我们创建 Grades 表,用于存储学生的成绩信息。我们将应用主键约束、外键约束和非空约束,并添加一个检查约束来确保成绩在有效范围内。

CREATE TABLE Grades (GradeID INT PRIMARY KEY,          -- 主键约束,确保每条成绩记录有一个唯一的IDStudentID INT,                    -- 学生ID,外键约束将引用Students表CourseName VARCHAR(100) NOT NULL, -- 课程名称,非空约束Grade DECIMAL(5, 2) CHECK (Grade BETWEEN 0 AND 100), -- 成绩字段,检查约束确保成绩在0到100之间FOREIGN KEY (StudentID) REFERENCES Students(StudentID) -- 外键约束,确保StudentID在Students表中存在
);
3. 插入数据示例

现在我们可以向这两个表中插入一些数据来验证约束是否有效。

-- 插入学生数据
INSERT INTO Students (StudentID, FirstName, LastName, Email, DateOfBirth)
VALUES
(1, 'John', 'Doe', 'john.doe@example.com', '2000-01-15'),
(2, 'Jane', 'Smith', 'jane.smith@example.com', '1999-07-22');-- 尝试插入一个重复的电子邮件地址(这将失败,因为Email列有唯一约束)
-- INSERT INTO Students (StudentID, FirstName, LastName, Email, DateOfBirth)
-- VALUES
-- (3, 'Alice', 'Johnson', 'john.doe@example.com', '2001-03-30');-- 插入成绩数据
INSERT INTO Grades (GradeID, StudentID, CourseName, Grade)
VALUES
(1, 1, 'Mathematics', 85.5),
(2, 2, 'Science', 92.0),
(3, 1, 'History', 78.0);-- 尝试插入一个超出范围的成绩(这将失败,因为Grade列有检查约束)
-- INSERT INTO Grades (GradeID, StudentID, CourseName, Grade)
-- VALUES
-- (4, 2, 'Art', 120.0);

结论

在这个例子中,我们展示了如何在创建表时应用不同类型的 SQL 约束来确保数据的完整性和准确性。主键约束确保了表中每条记录的唯一性;外键约束维护了表之间的关系;唯一约束确保了特定列中的值不重复;非空约束确保了列中不会有缺失的数据;检查约束则允许我们定义更复杂的规则来验证数据的有效性。

通过这些约束,我们可以防止无效数据的插入,从而确保数据库中的数据是可靠和准确的。

相关文章:

mysql学习教程,从入门到精通,SQL 约束(Constraints)(41)

在数据库设计中,约束(Constraints)用于确保数据的准确性和完整性。它们通过限制可以插入到数据库表中的数据类型来防止无效数据。SQL 中有几种常见的约束类型,包括主键约束(Primary Key)、外键约束&#xf…...

使用CSS3与JavaScript实现炫酷的3D旋转魔方及九宫格交换动效

文章目录 前言一、项目需求背景二、CSS3 3D基础知识介绍2.1 什么是CSS3 3D?2.2 主要使用的CSS属性 三、使用HTML和CSS搭建魔方结构四、让魔方动起来:CSS3动画五、九宫格数字交换的JavaScript实现5.1 九宫格布局5.2 随机交换数字 六、随机交换与相邻格子的…...

springboot项目通过maven的profile功能实现通过不同文件夹的方式来组织不同环境配置文件

写在前面 本文看下springboot项目如何通过文件夹的方式来组织不同环境配置文件。 1:正文 一般的我们写springboot项目时配置文件是这个样子的: appliction.yaml --> 通过spring.profiles.activexxx来激活某个指定后缀的配置文件 application-evn1…...

GAN(Generative Adversarial Nets)

GAN(Generative Adversarial Nets) 引言 GAN由Ian J. Goodfellow等人提出,是Ian J. Goodfellow的代表作之一,他还出版了大家耳熟能详的花书(Deep Learning深度学习),GAN主要的思想是同时训练两个模型,生成…...

linux下使用mpi求自然数和

搭建MPI并行计算环境,编写 MPI程序,求和 1 23....1 0000。 要求: 1.使用100个进程; 2.进程0计算1 2...100, 进程1计算101 102... 200, ..... 进程99计算9901 9902... 10000; 3.调用计时函数,分别输出每个进程的计算时间; 4.需使用MPI集群通信函数和同…...

WebGl学习使用attribute变量绘制一个水平移动的点

在WebGL编程中,attribute变量是一种特殊类型的变量,用于从客户端传递数据到顶点着色器。这些数据通常包括顶点的位置、颜色、纹理坐标等,它们是与每个顶点直接相关的信息。attribute变量在顶点着色器中声明,并且对于每个顶点来说都…...

机器学习四大框架详解及实战应用:PyTorch、TensorFlow、Keras、Scikit-learn

目录 框架概述PyTorch:灵活性与研究首选TensorFlow:谷歌加持的强大生态系统Keras:简洁明了的高层 APIScikit-learn:传统机器学习的必备工具实战案例 图像分类实战自然语言处理实战回归问题实战 各框架的对比总结选择合适的框架 1…...

linux源码安装slurm以及mung和openssl

一、源码安装munge 1、编译安装munge (1)下载munge地址:https://github.com/dun/munge/releases (2)解压编译安装: 1 2 3 4 5 6 7 8 创建/data目录 复制文件munge-0.5.15.tar.xz 到/data目录下 tar -Jx…...

分享蓝牙耳机A2DP音频卡顿原因及解决思路

背景 最近一直在更新博客,我觉得写博客有三个好处,一是很多东西时间久了就会忘,记下来方便自己以后回忆和总结,二是记下来可以加深自己对知识的理解,三是可以知识分享,方便他人。 言归正传,今天…...

Mac 下编译 libaom 源码教程

AV1 AV1是一种开放、免版税的视频编码格式,由开放媒体联盟(AOMedia)开发,旨在提供高压缩效率和优秀的视频质量。AV1支持多种分辨率,包括SD、HD、4K和8K,并适用于视频点播(VOD)、直播…...

【成品设计】基于Arduino平台的物联网智能灯

《基于Arduino平台的物联网智能灯》 整体功能: 这个任务中要求实现一个物联网智能灯。实际测试环境中要求设备能够自己创建一个热点,连接这个热点后能自动弹出控制界面(强制门户)。 功能点 基础功能 (60分) 要求作品至少有2个灯…...

安装和配置k8s可视化UI界面dashboard-1.20.6

安装和配置k8s可视化UI界面dashboard-1.20.6 1.环境规划2.初始化服务器1)配置主机名2)设置IP为静态IP3)关闭selinux4)配置主机hosts文件5)配置服务器之间免密登录6)关闭交换分区swap,提升性能7&…...

VLAN:虚拟局域网

VLAN:虚拟局域网 交换机和路由器协同工作后,将原先的一个广播域,逻辑上,切分为多个广播域。 第一步:创建VLAN [SW1]dispaly vlan 查询vlan VID(VLAN ID):用来区分和标定不同的vlan 由12位二进制构成 范围: 0-4…...

利用可解释性技术增强制造质量预测模型

概述 论文地址:https://arxiv.org/abs/2403.18731 本研究提出了一种利用可解释性技术提高机器学习(ML)模型性能的方法。该方法已用于铣削质量预测,这一过程首先训练 ML 模型,然后使用可解释性技术识别不需要的特征并去…...

FlexMatch: Boosting Semi-Supervised Learning with Curriculum Pseudo Labeling

FlexMatch: Boosting Semi-Supervised Learning with Curriculum Pseudo Labeling 摘要:引言:背景3 flexMatch3.1 Curriculum Pseudo Labeling3.2 阈值预热3.3非线性映射函数实验4.1 主要结果4.2 ImageNet上的结果4.3收敛速度加速4.4 消融研究5 相关工作摘要: 最近提出的Fi…...

Spring Cloud 3.x 集成eureka快速入门Demo

1.什么是eureka? Eureka 由 Netflix 开发,是一种基于REST(Representational State Transfer)的服务,用于定位服务(服务注册与发现),以实现中间层服务的负载均衡和故障转移&#xff…...

线性代数 矩阵

一、矩阵基础 1、定义 一组数按照矩形排列而成的数表;形似行列式,区别点是 矩阵行列式符号()或[]| |形状方阵或非方阵方阵本质数表数属性A|A|是A诸多属性中的一种维度m *n (m 与n可以相等也可以不相等)n*n 同型矩阵 若A、B两个矩阵都是mn 矩阵&#x…...

【C语言】使用结构体实现位段

文章目录 一、什么是位段二、位段的内存分配1.位段内存分配规则练习1练习2 三、位段的跨平台问题四、位段的应用五、位段使用的注意事项 一、什么是位段 在上一节中我们讲解了结构体,而位段的声明和结构是类似的,它们有两个不同之处,如下&…...

univer实现excel协同

快速入门 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title><script src&q…...

JavaScript进阶笔记--深入对象-内置构造函数及案例

深入对象 创建对象三种方式 利用对象字面量new Object&#xff08;{…}&#xff09;利用构造函数 // 1. 字面量创建对象const obj1 {name: pig,age: 18};console.log(obj1); // {name: "pig", age: 18}// 2. 构造函数创建对象function Pig(name, age) {this.name…...

C++实现分布式网络通信框架RPC(3)--rpc调用端

目录 一、前言 二、UserServiceRpc_Stub 三、 CallMethod方法的重写 头文件 实现 四、rpc调用端的调用 实现 五、 google::protobuf::RpcController *controller 头文件 实现 六、总结 一、前言 在前边的文章中&#xff0c;我们已经大致实现了rpc服务端的各项功能代…...

相机Camera日志实例分析之二:相机Camx【专业模式开启直方图拍照】单帧流程日志详解

【关注我&#xff0c;后续持续新增专题博文&#xff0c;谢谢&#xff01;&#xff01;&#xff01;】 上一篇我们讲了&#xff1a; 这一篇我们开始讲&#xff1a; 目录 一、场景操作步骤 二、日志基础关键字分级如下 三、场景日志如下&#xff1a; 一、场景操作步骤 操作步…...

Python爬虫实战:研究feedparser库相关技术

1. 引言 1.1 研究背景与意义 在当今信息爆炸的时代,互联网上存在着海量的信息资源。RSS(Really Simple Syndication)作为一种标准化的信息聚合技术,被广泛用于网站内容的发布和订阅。通过 RSS,用户可以方便地获取网站更新的内容,而无需频繁访问各个网站。 然而,互联网…...

【解密LSTM、GRU如何解决传统RNN梯度消失问题】

解密LSTM与GRU&#xff1a;如何让RNN变得更聪明&#xff1f; 在深度学习的世界里&#xff0c;循环神经网络&#xff08;RNN&#xff09;以其卓越的序列数据处理能力广泛应用于自然语言处理、时间序列预测等领域。然而&#xff0c;传统RNN存在的一个严重问题——梯度消失&#…...

关于 WASM:1. WASM 基础原理

一、WASM 简介 1.1 WebAssembly 是什么&#xff1f; WebAssembly&#xff08;WASM&#xff09; 是一种能在现代浏览器中高效运行的二进制指令格式&#xff0c;它不是传统的编程语言&#xff0c;而是一种 低级字节码格式&#xff0c;可由高级语言&#xff08;如 C、C、Rust&am…...

算法笔记2

1.字符串拼接最好用StringBuilder&#xff0c;不用String 2.创建List<>类型的数组并创建内存 List arr[] new ArrayList[26]; Arrays.setAll(arr, i -> new ArrayList<>()); 3.去掉首尾空格...

springboot整合VUE之在线教育管理系统简介

可以学习到的技能 学会常用技术栈的使用 独立开发项目 学会前端的开发流程 学会后端的开发流程 学会数据库的设计 学会前后端接口调用方式 学会多模块之间的关联 学会数据的处理 适用人群 在校学生&#xff0c;小白用户&#xff0c;想学习知识的 有点基础&#xff0c;想要通过项…...

Java编程之桥接模式

定义 桥接模式&#xff08;Bridge Pattern&#xff09;属于结构型设计模式&#xff0c;它的核心意图是将抽象部分与实现部分分离&#xff0c;使它们可以独立地变化。这种模式通过组合关系来替代继承关系&#xff0c;从而降低了抽象和实现这两个可变维度之间的耦合度。 用例子…...

2025年渗透测试面试题总结-腾讯[实习]科恩实验室-安全工程师(题目+回答)

安全领域各种资源&#xff0c;学习文档&#xff0c;以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各种好玩的项目及好用的工具&#xff0c;欢迎关注。 目录 腾讯[实习]科恩实验室-安全工程师 一、网络与协议 1. TCP三次握手 2. SYN扫描原理 3. HTTPS证书机制 二…...

JavaScript 数据类型详解

JavaScript 数据类型详解 JavaScript 数据类型分为 原始类型&#xff08;Primitive&#xff09; 和 对象类型&#xff08;Object&#xff09; 两大类&#xff0c;共 8 种&#xff08;ES11&#xff09;&#xff1a; 一、原始类型&#xff08;7种&#xff09; 1. undefined 定…...