Mysql之约束上篇

news2024/9/21 10:38:34

Mysql之约束上篇

  • 约束的概述
    • 为什么需要约束
    • 什么是约束
    • 约束的分类
  • 非空约束
    • 作用
    • 关键字
    • 特点
    • 添加非空约束
    • 删除非空约束
  • 唯一性约束
    • 关键字
    • 特点
    • 添加唯一约束
    • 关于复合唯一约束
    • 删除唯一约束
      • 查看索引
  • 主键约束(非空唯一性约束)
    • 作用
    • 关键字
    • 特点
    • 添加主键约束
    • 关于复合主键
    • 删除主键约束

约束的概述

为什么需要约束

数据完整性(Data Integrity)是指数据的精确性(Accuracy)和可靠性(Reliability)。它是防止数据库中存在不符合语义规定的数据和防止因错误信息的输入输出造成无效操作或错误信息而提出的。

为了保证数据的完整性,SQL规范以约束的方式对表数据进行额外的条件限制。从以下四个方面考虑:

1.实体完整性(Entity Integrity) :例如,同一个表中,不能存在两条完全相同无法区分的记录
2.域完整性(Domain Integrity) :例如:年龄范围0-120,性别范围“男/女”
3.引用完整性(Referential Integrity) :例如:员工所在部门,在部门表中要能找到这个部门
4.用户自定义完整性(User-defined Integrity) :例如:用户名唯一、密码不能为空等,本部门经理的工资不得高于本部门职工的平均工资的5倍。

什么是约束

约束是表级的强制规定。
可以在创建表时规定约束(通过 CREATE TABLE 语句),或者在表创建之后通过 ALTER TABLE 语句规定约束

约束的分类

根据约束数据列的限制,约束可分为:
1.单列约束:每个约束只约束一列
2.多列约束:每个约束可约束多列数据

根据约束的作用范围,约束可分为:
1.列级约束:只能作用在一个列上,跟在列的定义后面
2.表级约束:可以作用在多个列上,不与列一起,而是单独定义

在这里插入图片描述

这里注意:表级约束和列级约束的位置

根据约束起的作用,约束可分为:
1.NOT NULL 非空约束,规定某个字段不能为空
2.UNIQUE 唯一约束,规定某个字段在整个表中是唯一的
3.PRIMARY KEY 主键(非空且唯一)约束
4.FOREIGN KEY 外键约束
5.CHECK 检查约束
6.DEFAULT 默认值约束

非空约束

作用

他的作用跟名字一样,限定某一行或者某一列不为空
在这里插入图片描述

关键字

关键字:是NOT NULL

特点

1.默认,所有的类型的值都可以是NULL,包括INT、FLOAT等数据类型
2.非空约束只能出现在表对象的列上,只能某个列单独限定非空,不能组合非空
3.一个表可以有很多列都分别限定了非空
4.空字符串’'不等于NULL,0也不等于NULL

添加非空约束

方式一:建表的时候添加非空约束

CREATE TABLE 表名称(
字段名 数据类型,
字段名 数据类型 NOT NULL,
字段名 数据类型 NOT NULL
);

案例:

CREATE TABLE student
(
	name VARCHAR(20)  NOT NULL,
	sex  VARCHAR(20)
)

INSERT INTO student
VALUES('NIHAO', '男')

用DESC命令可查看表的信息 (看约束条件)
在这里插入图片描述

方式二:建表之后添加非空约束
如前面的案例,给sex数据成员,也加上非空约束的条件

ALTER TABLE 表名称 
MODIFY 字段名 数据类型 NOT NULL;
ALTER TABLE student
MODIFY sex VARCHAR(20) NOT NULL

查看此时表的信息

DESC student

在这里插入图片描述

删除非空约束

两种写法,也是用ALTER MODIFY 语句来实现
一种是去掉NOT NULL,一种是用NULL

#写法一:
ALTER TABLE 表名称 
MODIFY 字段名 数据类型 NULL;

#去掉not null,相当于修改某个非注解字段,该字段允许为空

#写法二:
ALTER TABLE 表名称 
MODIFY 字段名 数据类型;
ALTER TABLE student
MODIFY name VARCHAR(20) NULL

DESC student

在这里插入图片描述

ALTER TABLE student
MODIFY sex VARCHAR(20)

DESC student

在这里插入图片描述

唯一性约束

在这里插入图片描述

关键字

关键字是:UNIQUE

特点

1.同一个表可以有多个唯一约束。
2.唯一约束可以是某一个列的值唯一,也可以多个列组合的值唯一。
3.唯一性约束允许列值为空。
4.在创建唯一约束的时候,如果不给唯一约束命名,就默认和列名相同。
5.MySQL会给唯一约束的列上默认创建一个唯一索引。

添加唯一约束

添加唯一性约束有两种写法

#写法一:

create table 表名称(
字段名 数据类型,
字段名 数据类型 unique,
字段名 数据类型 unique key,
字段名 数据类型
);

#写法二:
create table 表名称(
字段名 数据类型,
字段名 数据类型,
字段名 数据类型,
[constraint 约束名] UNIQUE KEY(字段)
CREATE TABLE  student3
(
	name VARCHAR(20),
	sex  VARCHAR(20),
	number INT
)

#写法一:
ALTER TABLE student3
MODIFY name VARCHAR(20) UNIQUE

#写法二:
ALTER TABLE student3
ADD UNIQUE KEY(sex)

#查看表的信息
DESC student3

加粗样式
在这里插入图片描述

关于复合唯一约束

删除唯一约束

特点:
1.添加唯一性约束的列上也会自动创建唯一索引。
2.删除唯一约束只能通过删除唯一索引的方式删除
3.删除时需要指定唯一索引名,唯一索引名就和唯一约束名一样。
4.如果创建唯一约束时未指定名称,如果是单列,就默认和列名相同;如果是组合列,那么默认和()中排在第一个的列名相同。也可以自定义唯一性约束名。

查看索引

#查看索引的命令
SHOW INDEX FROM 表名

案例

#删除name的UNIQUE约束
ALTER TABLE student3
DROP  INDEX name

DESC student3

在这里插入图片描述

主键约束(非空唯一性约束)

作用

作用:用来唯一标识表中的一行记录。

关键字

primary key

特点

主键约束相当于唯一约束+非空约束的组合,主键约束列不允许重复,也不允许出现空值

在这里插入图片描述

1.一个表最多只能有一个主键约束,建立主键约束可以在列级别创建,也可以在表级别上创建。
2.主键约束对应着表中的一列或者多列(复合主键)
3.如果是多列组合的复合主键约束,那么这些列都不允许为空值,并且组合的值不允许重复。
4.MySQL的主键名总是PRIMARY,就算自己命名了主键约束名也没用。

5.当创建主键约束时,系统默认会在所在的列或列组合上建立对应的主键索引(能够根据主键查询的,就根据主键查询,效率更高)。如果删除主键约束了,主键约束对应的索引就自动删除了。

  1. 需要注意的一点是,不要修改主键字段的值。因为主键是数据记录的唯一标识,如果修改了主键的值,就有可能会破坏数据的完整性。

添加主键约束

同样两种情况,
1.建表的时候,添加主键约束

create table student6
(
	id int,
	name varchar(20),
	primary key(id, name) 
);

DESC student6

create table student8
(
	id int primary key,
	name varchar(20)
)

DESC  student8

在这里插入图片描述

在这里插入图片描述

关于复合主键

create table 表名称(
字段名 数据类型,
字段名 数据类型,
字段名 数据类型,
primary key(字段名1,字段名2) #表示字段1和字段2的组合是唯一的,也可以有更多个字段
);
#学生表
create table student(
sid int primary key, #学号
sname varchar(20) #学生姓名
);
#课程表
create table course(
cid int primary key, #课程编号
cname varchar(20) #课程名称
);
#选课表
create table student_course(
sid int,
cid int,
score int,
primary key(sid,cid) #复合主键
)

在这里插入图片描述

删除主键约束

说明:删除主键约束,不需要指定主键名,因为一个表只有一个主键,删除主键约束后,非空还存在。


#删除主键约束的语法格式
alter table 表名称 drop primary key;

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

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

相关文章

使用pytest+selenium+allure实现web页面自动化测试

测试文件 base 基本方法data 测试数据page web页面相关操作image 测试截图log 日志文件report 测试报告文件temp 临时文件tool 文件读取,发邮件文件TestCases 测试用例 在page下的__init__.py文件下配置 import os import time from selenium.webdriver.common.by…

【小沐学Unity3d】3ds Max 减面工具:Simplyon(Unity3d,Python)

文章目录 1、简介2、下载安装2.1 安装Simlygon插件2.2 安装USD插件 3、使用测试4、Python测试结语 1、简介 Simplygon 带有一个 Unity 插件,它公开了优化功能,例如缩减、聚合、重新划分网格、冒名顶替者(SingleView、BillboardCloud / Veget…

PDF控件Spire.PDF for .NET【安全】演示:将加密或解密 PDF 文件

当涉及到在 Internet 上共享机密文档时,PDF 加密是一项至关重要的任务。通过使用强密码加密 PDF 文件,您可以保护文件数据免遭未经授权的人员访问。在某些情况下,可能还需要删除密码才能公开文档。在本文中,您将了解如何使用Spire…

spring-validation实现分组校验

文章目录 前言实际开发可能会使用到分组校验maven添加依赖简单使用高级应用分组自定义分组组合分组 源码地址 前言 JSR 303中提出了Bean Validation,表示JavaBean的校验,Hibernate Validation是其具体实现,并对其进行了一些扩展,…

WEB绘图插件Canvas基础应用

一、概述 canvas 是 html5 标准中提供的⼀个标签 顾名思义是定义在浏览器上的画布,通过其强大的绘图接口,我们可以实现各种各样的图形, 炫酷的动画 ,甚至可以利用他开发⼩游戏,包括市面上很流行的数据可视化框架底层都…

【新手必看】PyCharm2023免费下载安装配置教程+Python环境搭建、图文并茂全副武装学起来才嗖嗖的快,绝对最详细!

🚀 个人主页 极客小俊 ✍🏻 作者简介:web开发者、设计师、技术分享博主 🐋 希望大家多多支持一下, 我们一起学习和进步!😄 🏅 如果文章对你有帮助的话,欢迎评论 💬点赞&a…

logback.xml

logback.xml <?xml version"1.0" encoding"UTF-8"?> <configuration><!-- 日志存放路径 --><property name"log.path" value"./logs" /><!-- 日志输出格式 --><property name"log.pattern&q…

释放潜力:前端开发者转向鸿蒙的必备建议

如果需要JavaScript知识点可以去我的主要观看 大家有关于JavaScript知识点不知道可以去 &#x1f389;博客主页&#xff1a;阿猫的故乡 &#x1f389;系列专栏&#xff1a;JavaScript专题栏 &#x1f389;ajax专栏&#xff1a;ajax知识点 &#x1f389;欢迎关注&#xff1a;&am…

【离散数学】——期末刷题题库(图论应用题)

&#x1f383;个人专栏&#xff1a; &#x1f42c; 算法设计与分析&#xff1a;算法设计与分析_IT闫的博客-CSDN博客 &#x1f433;Java基础&#xff1a;Java基础_IT闫的博客-CSDN博客 &#x1f40b;c语言&#xff1a;c语言_IT闫的博客-CSDN博客 &#x1f41f;MySQL&#xff1a…

力扣:203. 移除链表元素(Python3)

题目&#xff1a; 给你一个链表的头节点 head 和一个整数 val &#xff0c;请你删除链表中所有满足 Node.val val 的节点&#xff0c;并返回 新的头节点 。 来源&#xff1a;力扣&#xff08;LeetCode&#xff09; 链接&#xff1a;力扣&#xff08;LeetCode&#xff09;官网 …

Windows 截图工具①FastStone Capture ②PixPin

​ 今天说说Windows好用的载图软件&#xff1a; 2023年12月21日&#xff0c;更新新增 PixPin 2款超级好用的截图软件&#xff0c;不止是载图、编辑、录屏、Gif等好用的功能&#xff0c;本人一直也在用。 ①FastStone Capture ②PixPin 软件介绍&#xff1a;FastStone Fast…

2024年【公路水运工程施工企业安全生产管理人员】考试题及公路水运工程施工企业安全生产管理人员报名考试

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 2024年【公路水运工程施工企业安全生产管理人员】考试题及公路水运工程施工企业安全生产管理人员报名考试&#xff0c;包含公路水运工程施工企业安全生产管理人员考试题答案和解析及公路水运工程施工企业安全生产管理…

还在用nvm?来试试更快的node版本管理工具——fnm

前言 &#x1f4eb; 大家好&#xff0c;我是南木元元&#xff0c;热衷分享有趣实用的文章&#xff0c;希望大家多多支持&#xff0c;一起进步&#xff01; &#x1f345; 个人主页&#xff1a;南木元元 目录 什么是node版本管理 常见的node版本管理工具 fnm是什么 安装fnm …

4+miRNA+机器学习生信思路,常规又简单的miRNA也能发4+

今天给同学们分享一篇生信文章“Machine learning algorithms reveal potential miRNAs biomarkers in gastric cancer”&#xff0c;这篇文章发表在Sci Rep期刊上&#xff0c;影响因子为4.6。 结果解读&#xff1a; 数据来源 本研究包括348名男性&#xff08;占64.9%&#x…

解析资产管理的革新之路:从手工盘点到易点易动RFID散步式方案

随着科技的不断进步和应用&#xff0c;资产管理领域也在不断演进和革新。从最初的手工盘点到现代的智能化解决方案&#xff0c;我们目睹了资产管理的巨大变革。其中&#xff0c;易点易动RFID散步式方案以其高效、准确和便捷的特点&#xff0c;正在成为资产管理的新宠。本文将深…

Linux之yum管理器

目录 yum管理器 yum相关指令 yum list yum list | grep yum install yum remove 拓展 1.yum install -y man-pages 2.切换yum源 3.yum install -y epel-release 4. yum install -y lrzsz rz指令 sz指令 在window系统上&#xff0c;我们会在电脑自带的应用商…

Android Studio使用Genymotion

1. Genymotion介绍 GenyMotion速度之快令人发指&#xff0c;模拟效果堪比真机调试&#xff0c;支持绝大部分的模拟器功能&#xff0c;甚至包括语音&#xff0c;Google Now&#xff0c;支持eclipse, android studio。非常适合用来开发和演示效果。 2. Genymotion下载 Genymotio…

上 GitHub 热榜,星星暴涨,这个项目相继超越了 Archery, Flyway 和 Yearning

「 登上 GitHub Trending 星星超越 Yearning 键盘的敲击不停 传播开发的福音 」⚡️ Bytebase 是一款面向开发和 DBA 的一站式数据库 CI/CD 工具。它的所有代码都开源在 GitHub 上。GitHub 也是我们触达全球用户的核心阵地。虽然 GitHub Star 数一直是一个饱受争议的指标&a…

深度学习模型压缩方法:剪枝方法分类介绍

本文将介绍深度学习模型压缩方法中的剪枝,内容从剪枝简介、剪枝步骤、结构化剪枝与非结构化剪枝、静态剪枝与动态剪枝、硬剪枝与软剪枝等五个部分展开。 一、剪枝简介 在介绍剪枝之前,首先介绍过参数化这个概念,过参数化主要是指在训练阶段,在数学上需要进行大量的微分求解…

外贸函电开发信模板?写客户开发邮件方法?

如何写好外贸函电开发信&#xff1f;英语函电中的开发信怎么写&#xff1f; 在国际贸易中&#xff0c;外贸函电开发信扮演着至关重要的角色。这是一种有效的沟通工具&#xff0c;用来建立和维护与潜在客户或合作伙伴的联系。在这篇文章中&#xff0c;蜂邮将为您提供一个外贸函…