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 约束来确保数据的完整性和准确性。主键约束确保了表中每条记录的唯一性;外键约束维护了表之间的关系;唯一约束确保了特定列中的值不重复;非空约束确保了列中不会有缺失的数据;检查约束则允许我们定义更复杂的规则来验证数据的有效性。

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

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

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

相关文章

前端遮罩层的应用

最近微信小程序需要开发新手引导功能&#xff0c;发现需要在遮罩层中间抠一个洞出来&#xff0c;但是一直不知道该怎么去做&#xff0c;其实很简单&#xff0c;先展示源码&#xff1a; <template><div class"num01">hello<div class"mask"&…

ai字幕用什么软件制作?6款视频加字幕工具分享!

在视频制作和后期处理中&#xff0c;字幕的添加是一个重要的环节。随着AI技术的发展&#xff0c;越来越多的软件开始支持AI自动加字幕功能&#xff0c;使得字幕的制作变得更加简单和高效。本文将为大家介绍几款常用的AI字幕制作软件&#xff0c;并详细讲解如何使用AI自动加字幕…

PyTorch 的 DataLoader 类介绍

DataLoader 类 功能与作用 PyTorch 是一个流行的开源机器学习库&#xff0c;它提供了一个名为 DataLoader 的类&#xff0c;用于加载数据集并将其封装成一个可迭代的对象。DataLoader 可以自动地将数据集划分为多个批次&#xff0c;并在训练过程中迭代地返回这些批次。是用于加…

【MySQL 保姆级教学】在Linux(CentoS 7)中安装MySQL(1)

目录 1. 卸载linux&#xff08;Centos7&#xff09; 中不要的环境2. 获取MySQL官方yum源2.1 获取yum源前先查看自己 linux&#xff08;Centos&#xff09;的版本2.2 获取官方yum源 3. 安装xftp和连接4. 开放连接端口5. 上传文件到Centos76. 安装MySQL6.1 顺利安装6.2 查询是否安…

从RNN讲起(RNN、LSTM、GRU、BiGRU)——序列数据处理网络

文章目录 RNN&#xff08;Recurrent Neural Network&#xff0c;循环神经网络&#xff09;1. 什么是RNN&#xff1f;2. 经典RNN的结构3. RNN的主要特点4. RNN存在问题——长期依赖&#xff08;Long-TermDependencies&#xff09;问题 LSTM&#xff08;Long Short-Term Memory&a…

某MDM主数据管理系统与微软Dynamic CRM系统(国内节点)集成案例

一、需求分析 需要完成的核心场景&#xff1a; 客户主数据&#xff1a;通过SAP PO集成中间件平台&#xff0c;某MDM主数据实时推送客户主数据信息至微软CRM系统&#xff0c;方便微软CRM系统进行客户方面的管理&#xff0c;并供微软CRM查询员工信息&#xff0c;修改员工&…

STM32—FLASH闪存

1.FLASH简介 STM32F1系列的FLASH包含程序存储器、系统存储器和选项字节三个部分&#xff0c;通过闪存存储器接口&#xff08;外设&#xff09;可以对程序存储器和选项字节进行擦除和编程 我们怎么操作这些存储器呢&#xff1f;这就需要用到这个闪存存储器接口了&#xff0c;闪…

Go语言Gin框架的常规配置和查询数据返回json示例

文章目录 路由文件分组查询数据库并返回jsonservice层controller路由运行效果 启动多个服务 在 上一篇文章《使用Go语言的gorm框架查询数据库并分页导出到Excel实例》 中主要给大家分享了较多数据的时候如何使用go分页导出多个Excel文件并合并的实现方案&#xff0c;这一篇文章…

2-127基于matlab的非圆齿轮啮合动画设计

基于matlab的非圆齿轮啮合动画设计&#xff0c;可根据需求设置齿数&#xff0c;齿高、平滑系数等&#xff0c;最后输出啮合动画。程序已调通&#xff0c;可直接运行。 下载源程序请点链接&#xff1a;2-127基于matlab的非圆齿轮啮合动画设计

day-13面向对象进阶

面向对象进阶部分学习方法&#xff1a; 特点&#xff1a; ​ 逻辑性没有那么强&#xff0c;但是概念会比较多。 ​ 记忆部分重要的概念&#xff0c;理解课堂上讲解的需要大家掌握的概念&#xff0c;多多练习代码。 day13 第一章 复习回顾 1.1 如何定义类 类的定义格式如…

1.Node.js环境搭建(windows)

一、环境搭建(windows) 1.1下载并安装 https://nodejs.org/dist/v18.20.4/node-v18.20.4-x64.msi1.2测试和查看版本 #cmd命令 node -v输出&#xff1a; #能正确输出版本号&#xff0c;说明安装成功 v18.20.41.3使用nodejs启动第一个js #hello.js console.log(hello world!…

如何接受Date范围的数据

controller 注解 @DateTimeFormat 会自动完成字符串到LocalDate的转换/*** 报表的接口*/ @RestController @RequestMapping("/admin/report") @Api(tags = "报表的接口") @Slf4j @RequiredArgsConstructor(onConstructor = @__(@Autowired)) public class …

探索Python配置新维度:Hydra库揭秘

文章目录 探索Python配置新维度&#xff1a;Hydra库揭秘背景&#xff1a;为何选择Hydra&#xff1f;初识Hydra安装Hydra简单的库函数使用方法基础配置覆盖配置组合配置多运行 场景应用数据库配置本地和远程运行多作业运行 常见Bug及解决方案配置加载失败命令行参数解析错误远程…

014_django基于大数据运城市二手房价数据可视化系统的设计与实现2024_3ahrxq75

目录 系统展示 开发背景 代码实现 项目案例 获取源码 博主介绍&#xff1a;CodeMentor毕业设计领航者、全网关注者30W群落&#xff0c;InfoQ特邀专栏作家、技术博客领航者、InfoQ新星培育计划导师、Web开发领域杰出贡献者&#xff0c;博客领航之星、开发者头条/腾讯云/AW…

C语言的结构体定义 java赋值关系运算符

1. /*#include<stdio.h> struct student { int num; //成员列表 int score; float avg; }; int main(void) { struct student Tom;//Tom结构体变量 struct student class4[50];//结构体数组 return 0; }*/ struct student { int nu…

测试右移实践的一些总结思考—稳定监控“及时雨”

随着项目开发的逐渐敏捷化&#xff0c;QA的职能早已不单单是曾经简单对功能的测试&#xff0c;在领域内测试左移和测试右移这两个概念被一再提及。 本文将分别从稳定发布、监控、风险控制三个方面&#xff0c;主要介绍一下目前测试右移概念在组内的落地应用、一些还没有落地的…

Wordpress GutenKit 插件 远程文件写入致RCE漏洞复现(CVE-2024-9234)

0x01 产品简介 GutenKit 是一个WordPress的页面构建器,在 Gutenberg 设计您的下一个 WordPress 网站。借助 Gutenberg 的原生拖放界面、50+ WordPress 块、14+ 多功能模块和 500+ 模板,您可以在几分钟内创建专业、响应迅速的 Web 内容。 0x02 漏洞概述 Wordpress GutenKit…

vue-router钩子中调用ElMessage等样式出错

升级 vue3.5 时遇到奇怪的问题, 页面点击离开没反应 经过排查, 是以下几点相互作用导致此问题 vue 有应用上下文的概念, 例如 runWithContext API,vue-router 在调用钩子时会获取 vue 的应用上下文element-plus 在唤起弹窗时会从 parent 或 应用上下文上拿到 config 信息eleme…

OpenCV高级图形用户界面(20)更改窗口的标题函数setWindowTitle()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 在OpenCV中&#xff0c;cv::setWindowTitle函数用于更改窗口的标题。这使得您可以在程序运行时动态地更改窗口的标题文本。 函数原型 void cv::…

JavaScript 中怎么判断前端各种运行环境

在 JavaScript 中&#xff0c;可以通过多种方式来判断前端应用的运行环境&#xff0c;比如浏览器环境、Node.js 环境、React Native 环境等。以下是一些常见的方法&#xff1a; 目录 1. 判断是否在浏览器环境中 2. 判断是否在 Node.js 环境中 3. 判断是否在 React Native 环…