前言

从今天开始本系列就带各位小伙伴学习数据库技术。数据库技术是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. 常用的约束有主键约束、唯一约束、非空约束需要各位小伙伴熟练掌握哦。

MySQL数据库之数据库约束,一文带你了解相关推荐

  1. mysql 导出dmp文件_一文带你了解MySQL主从复制(Master-Slave)

    1.复制概述 Mysql内建的复制功能是构建大型,高性能应用程序的基础.将Mysql的数据分布到多个系统上去,这种分布的机制,是通过将Mysql的某一台主机的数据复制到其它主机(slaves)上,并重 ...

  2. mysql三国人物库_一文带你使用neo4j生成三国人物社交关系图

    简介 最近给孩子买了三国演义,可是三国人物关系太复杂,就想着把三国人物关系做成一张图,这样方便看,整好neo4j图数据库非常适合社交关系的处理,下面就一起来看看,如何使用neo4j生成三国人物社交关系 ...

  3. 一文带你掌握MYSQL数据库

    什么是数据库? 1.数据库:保存有组织的数据的容器 2.数据库表:某种特定类型数据的结构化清单 (注)可以将数据库和数据库表比作文件夹和文件,同一个文件夹中不能存在相同文件名的文件,同理,同一个数据库 ...

  4. mysql数据库结构导出word_Windows导出MySQL数据库表结构到Word文档-DBExportDoc V1.0 For MySQL...

    必要条件: 1.Microsoft Office Word(我用WPS不行) 2.mysql-connector-odbc 3.会看文档 下载地址:关注微信公众号:八四七,回复5获取,压缩包中包含有具 ...

  5. 【工具篇】利用DBExportDoc V1.0 For MySQL自动生成数据库表结构文档(转

    对于DBA或开发来说,如何规范化你的数据库表结构文档是灰常之重要的一件事情.但是当你的库,你的表排山倒海滴多的时候,你就会很头疼了. 推荐一款工具DBExportDoc V1.0 For MySQL( ...

  6. mysql int 默认值 为ull_mysql的 约束 数据库设计 数据库 存储 触发器 mysql 权限问题...

    今天的目标: mysql的 约束 数据库设计 数据库 存储 触发器 mysql 权限问题 先讲约束: 要他唯一 不能重复 不能空值 : 什么是 mysql的约束: 对mysql 进行约束 2.2  默 ...

  7. mysql中ak替换键_数据库:唯一性约束_alternate key(替换键) mySQL Oracle 数据库 ak 唯一性约束...

    数据库:唯一性约束_alternate key(替换键) mySQL Oracle 数据库 ak 唯一性约束 数据库:唯一性约束 所谓唯一性约束(unique constraint)不过是数据表内替代 ...

  8. mysql数据库约束详解_基于MySQL数据库的数据约束实例及五种完整性约束介绍

    为了防止不符合规范的数据进入数据库,在用户对数据进行插入.修改.删除等操作时,DBMS自动按照一定的约束条件对数据进行监测,使不符合规范的数据不能进入数据库,以确保数据库中存储的数据正确.有效.相容. ...

  9. 零基础带你学习MySQL—备份恢复数据库(三)

    零基础带你学习MySQL-备份恢复数据库(三) 一.备份数据库 二.恢复数据库 先删除数据库zs_db03 恢复数据库zs_db03 课堂练习 方法一:傻瓜式办法 直接Ctrlcv 方法二:命令行方法 ...

  10. mysql 乱码 越南_mysql数据库乱码之保存越南文乱码解决方法

    我自己测试一下,很多字符变成了 '?'. 数据库连接已经是使用了 utf8 字符集: 复制代码 代码如下:define("MYSQL_ENCODE", "UTF8&quo ...

最新文章

  1. jca分析java dump日志
  2. POJ 2096 (概率DP)
  3. AttributeError:module 'numbers' has no attribute 'Integral'.
  4. java list字符排序吗_List中存放字符串进行排序
  5. 「技术人生」:技术同学应该如何理解业务?
  6. python 获取指定目录下的图片文件
  7. 在物欲横流,心浮气躁的今天,毕业生靠什么来维持自己的梦想?
  8. python项目-每日日考系统-数据结构
  9. (转)动态规划和贪心算法的区别
  10. 信息熵,条件熵,相对熵,交叉熵
  11. XML命名空间和相关类简介
  12. python文件操作:文件指针移动、修改
  13. ANC 调试 Performance
  14. 【翠花学Vue】每日打卡——vue打卡6
  15. 基于Python3.6和Opencv3的活动轮廓模型--CV和RSF
  16. symlink(): Protocol error
  17. 重复照片查找软件Duplicate Photos Sweeper Mac
  18. OCSP在线证书状态协议内容描述
  19. 阿里云服务器开放80端口
  20. Mac下手动安装Tex/Latex Package

热门文章

  1. 关于数据库事务隔离级别的介绍
  2. primary key与unique的区别
  3. php标题行,php 显示标题
  4. node中使用es6语法
  5. MySQL参数优化:back_log
  6. Winetricks最新版本安装
  7. 20级计算机应用数学试题,计算机等级考试试题试卷及答案.doc
  8. 如何用java创建一个文件
  9. matlab 中atan2函数的介绍
  10. usaco 奶牛集会 奶牛抗议