百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

MySQL数据库之数据库约束,一文带你了解

yuyutoo 2024-10-12 01:00 4 浏览 0 评论

前言

从今天开始本系列就带各位小伙伴学习数据库技术。数据库技术是Java开发中必不可少的一部分知识内容。也是非常重要的技术。本系列教程由浅入深, 全面讲解数据库体系。 非常适合零基础的小伙伴来学习。

全文大约【1785】,不说废话,只讲可以让你学到技术、明白原理的纯干货!本文带有丰富案例及配图,让你更好的理解和运用文中的技术概念,并可以给你带来具有足够启迪的思考......

一. 约束

什么是约束呢?约束就是对数据的制约和限定条件,各位小伙伴下面跟着我们的思路走,思考下面问题:

问题:在往已创建表中新增数据时,可不可以新增两行相同列值得数据?

如果可行,会有什么弊端?

数据重复了,那么肯定会白白浪费服务器的存储空间。所以就一定需要对数据进行限制和约束,设定数据填写的限制条件。

1. 主键约束

PRIMARY KEY唯一,标识表中的一行数据,此列的值不可重复,且不能为 NULL。

#1.为表中适用主键的列添加主键约束。
CREATE TABLE subject(
subjectId INT PRIMARY KEY, #课程编号标识每一个课程的编号唯一,且不能为 NULL。
subjectName VARCHAR(20),
subjectHours INT
)charset=utf8;

#2.这一条数据会正确插入。
INSERT INTO subject(subjectId,subjectName,subjectHours) VALUES(1,'Java',40);
#3.error主键1已存在,所以插入报错。
INSERT INTO subject(subjectId,subjectName,subjectHours) VALUES(1,'Java',40);

2. 唯一约束

UNIQUE唯一,标识表中的一行数据,不可重复,可以为 NULL。

#1.为表中列值不允许重复的列添加唯一约束。
CREATE TABLE subject(
subjectId INT PRIMARY KEY,
subjectName VARCHAR(20) UNIQUE, #课程名称唯一。
subjectHours INT
)charset=utf8;

#2.此条数据会正确插入。
INSERT INTO subject(subjectId,subjectName,subjectHours) VALUES(1,'Java',40);
#3.error课程名称已存在,违反唯一约束。
INSERT INTO subject(subjectId,subjectName,subjectHours) VALUES(2,'Java',40);

3. 自动增长列

AUTO_INCREMENT自动增长,给主键数值列添加自动增长。从1开始,每次加1。不能单独使用,和主键配合。

#1.为表中主键列添加自动增长,避免忘记主键ID序号。
CREATE TABLE subject(
subjectId INT PRIMARY KEY AUTO_INCREMENT,#课程编号主键且自动增长,会从 1 开始根据添加数据的顺序依次加 1
subjectName VARCHAR(20) UNIQUE,
subjectHours INT
)charset=utf8;

#2.课程编号自动从1增长。
INSERT INTO subject(subjectName,subjectHours) VALUES('Java',40);
#3.第二条编号为2。
INSERT INTO subject(subjectName,subjectHours) VALUES('JavaScript',30);

4. 非空约束

NOT NULL非空,此列必须有值。

#1.课程名称虽然添加了唯一约束,但是有 NULL 值存在的可能,要避免课程名称为 NULL。
CREATE TABLE subject(
subjectId INT PRIMARY KEY AUTO_INCREMENT,
subjectName VARCHAR(20) UNIQUE NOT NULL,
subjectHours INT
)charset=utf8;

#2.error课程名称约束了非空。
INSERT INTO subject(subjectName,subjectHours) VALUES(NULL,40);

5. 默认值约束

DEFAULT 值为列赋予默认值,当新增数据不指定值时,书写DEFAULT,以指定的默认值进行填充。

#1.当存储课程信息时,若课程时长没有指定值,则以默认课时 20 填充。
CREATE TABLE subject(
subjectId INT PRIMARY KEY AUTO_INCREMENT,
subjectName VARCHAR(20) UNIQUE NOT NULL,
subjectHours INT DEFAULT 20
)charset=utf8;

#2.课程时长以默认值 20 填充。
INSERT INTO subject(subjectName,subjectHours) VALUES('Java',DEFAULT);

6. 引用完整性约束

这个引用完整性约束健哥解释一下哈。指的是数据的一致性和正确性。完整性约束是指数据库的内容必须随时遵守的规则。若定义了数据完整性约束,MySQL会负责数据的完整性,每次更新数据时,MySQL都会测试新的数据内容是否符合相关的完整性约束条件,只有符合完整性的约束条件的更新才被接受。

语法:CONSTRAINT 引用名 FOREIGN KEY(列名) REFERENCES 被引用表名(列名)

详解:FOREIGN KEY引用外部表的某个列的值,新增数据时,约束此列的值必须是引用表中存在的值。

#1.创建专业表。
CREATE TABLE Speciality(
id INT PRIMARY KEY AUTO_INCREMENT,
SpecialName VARCHAR(20) UNIQUE NOT NULL
)CHARSET=utf8;

#2.创建课程表(课程表的SpecialId 引用专业表的 id)。
CREATE TABLE subject(
subjectId INT PRIMARY KEY AUTO_INCREMENT,
subjectName VARCHAR(20) UNIQUE NOT NULL,
subjectHours INT DEFAULT 20,
specialId INT NOT NULL,
#3.引用专业表里的 id 作为外键,新增课程信息时,约束课程所属的专业。
CONSTRAINT fk_subject_specialId  FOREIGN KEY(specialId) REFERENCES Speciality(id)
)charset=utf8;

#4.专业表新增数据。
INSERT INTO Speciality(SpecialName) VALUES('Java');
INSERT INTO Speciality(SpecialName) VALUES('C#');

#5.课程信息表添加数据
#专业 id 为 1,引用的是专业表的 Java。
INSERT INTO subject(subjectName,subjectHours) VALUES('Java',30,1);
#专业 id 为 2,引用的是专业表的 C#。
INSERT INTO subject(subjectName,subjectHours) VALUES('C#MVC',10,2);

注意:

创建关系表时,一定要先创建主表,再创建从表。

当两张表存在引用关系,要执行删除操作,一定要先删除从表(引用表),再删除主表(被引用表)。


二. 结语

最后在这里对本文核心要点进行总结:

1. 约束就是对数据的限制这样可以避免无效数据,垃圾数据的存在。

2. 常用的约束有主键约束、唯一约束、非空约束需要各位小伙伴熟练掌握哦。


更多精彩内容,关注@千锋教育

相关推荐

自卑的人容易患抑郁症吗?(自卑会导致抑郁吗)

Filephoto[Photo/IC]Lowself-esteemmakesusfeelbadaboutourselves.Butdidyouknowthatovert...

中考典型同(近)义词组(同义词考题)

中考典型同(近)义词组...

WPF 消息传递简明教程(wpf messagebox.show)

...

BroadcastReceiver的原理和使用(broadcast-suppression)

一、使用中注意的几点1.动态注册、静态注册的优先级在AndroidManifest.xml中静态注册的receiver比在代码中用registerReceiver动态注册的优先级要低。发送方在send...

Arduino通过串口透传ESP 13板与java程序交互

ESP13---是一个无线板子,配置通过热点通信Arduino通过串口透传ESP13板与java程序交互...

zookeeper的Leader选举源码解析(zookeeper角色选举角色包括)

作者:京东物流梁吉超zookeeper是一个分布式服务框架,主要解决分布式应用中常见的多种数据问题,例如集群管理,状态同步等。为解决这些问题zookeeper需要Leader选举进行保障数据的强一致...

接待外国人英文口语(接待外国友人的英语口语对话)

接待外国人英文口语询问访客身份:  MayIhaveyourname,please?  请问您贵姓?  Whatcompanyareyoufrom?  您是哪个公司的?  Could...

一文深入理解AP架构Nacos注册原理

Nacos简介Nacos是一款阿里巴巴开源用于管理分布式微服务的中间件,能够帮助开发人员快速实现动态服务发现、服务配置、服务元数据及流量管理等。这篇文章主要剖析一下Nacos作为注册中心时其服务注册与...

Android面试宝典之终极大招(android面试及答案)

以下内容来自兆隆IT云学院就业部,根据多年成功就业服务经验,以及职业素养课程部分内容,归纳总结:18.请描述一下Intent和IntentFilter。Android中通过Intent...

除了Crontab,Swoole Timer也可以实现定时任务的

一般的定时器是怎么实现的呢?我总结如下:1.使用Crontab工具,写一个shell脚本,在脚本中调用PHP文件,然后定期执行该脚本;2.ignore_user_abort()和set_time_li...

Spark源码阅读:DataFrame.collect 作业提交流程思维导图

本文分为两个部分:作业提交流程思维导图关键函数列表作业提交流程思维导图...

使用Xamarin和Visual Studio开发Android可穿戴设备应用

搭建开发环境我们需要做的第一件事情是安装必要的工具。因此,你需要首先安装VisualStudio。如果您使用的是VisualStudio2010,2012或2013,那么请确保它是一个专业版本或...

Android开发者必知的5个开源库(android 开发相关源码精编解析)

过去的时间里,Android开发逐步走向成熟,一个个与Android相关的开发工具也层出不穷。不过,在面对各种新鲜事物时,不要忘了那些我们每天使用的大量开源库。在这里,向大家介绍的就是,在这个任劳任怨...

Android事件总线还能怎么玩?(android实现事件处理的步骤)

顾名思义,AndroidEventBus是一个Android平台的事件总线框架,它简化了Activity、Fragment、Service等组件之间的交互,很大程度上降低了它们之间的耦合,使我们的代码...

Android 开发中文引导-应用小部件

应用小部件是可以嵌入其它应用(例如主屏幕)并收到定期更新的微型应用视图。这些视图在用户界面中被叫做小部件,并可以用应用小部件提供者发布。可以容纳其他应用部件的应用组件叫做应用部件的宿主(1)。下面的截...

取消回复欢迎 发表评论: