Skip to main content

Command Palette

Search for a command to run...

MySQL | 数据库表字段约束

Published
2 min read
MySQL | 数据库表字段约束

数据定义语言:字段约束

数据库的范式

  • 构造数据库必须遵循一定的规则,这种规则就是范式
  • 目前关系数据库有 6 种范式,一般情况下,只满足第三范式即可

第一范式:原子性

  • 第一范式是数据库的基本要求,不满足这一点就不是关系数据库
  • 数据表的每一列都是不可分割的基本数据项,同一列中不能有多个值,也不能存在重复的属性。

14

第二范式:唯一性

  • 数据表中的每条记录必须是唯一的。为了实现区分,通常要为表上加一个列用来存储唯一标识,这个唯一属性列被称作主键列

15

第三范式:关联性

  • 每列都与主键有直接关系,不存在传递依赖

16

  • 依照第三范式,数据可以拆分保存到不同的数据表,依次保持关联

17

字段约束

  • MySQL 中的字段约束共有四种:
约束名称关键字描述
主键约束PRIMARY KEY字段值唯一,且不能为 NULL
非空约束NOT NULL字段值不能为 NULL
唯一约束UNIQUE字段值唯一,且可以为 NULL
外键约束FOREIGN KEY保持关联数据的逻辑性
  • 外键约束是唯一不推荐使用的约束

主键约束

  • 主键约束要求字段的值在全表必须唯一,而且不能为 NULL
  • 建议主键一定要使用数据类型,因为数字的检索速度会非常快
  • 如果主键是数字类型,还可以设置自动增长
CREATE TABLE t_teacher(
    id INT PRIMARY KEY AUTO_INCREMENT,
    ... ...
);

非空约束

  • 非空约束要求字段的值不能为 NULL
  • NULL 值为没有值,而不是 "" 空字符串
CREATE TABLE t_teacher(
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(200) NOT NULL,
    married BOOLEAN NOT NULL DEFAULT FALSE
);
  • BOOLEAN 实际为TINYINT 数据类型

唯一约束

  • 唯一约束要求字段值如果不为 NULL,那么在全表必须唯一
CREATE TABLE t_teacher(
    ......
    tel CHAR(11) NOT NULL UNIQUE
);

以上三种的练习

CREATE TABLE t_teacher(
    id INT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(20) NOT NULL,
    tel CHAR(11) NOT NULL UNIQUE,
    married BOOLEAN NOT NULL DEFAULT FALSE
);

外键约束(放弃)

  • 外键约束用来保证关联数据的逻辑关系

18

  • 外键约束的定义是写在字表上的

创建父表

CREATE TABLE t_dept(
    deptno INT UNSIGNED PRIMARY KEY,
    dname VARCHAR(20) NOT NULL UNIQUE,
    tel CHAR(4) UNIQUE
);

创建子表

CREATE TABLE t_emp(
    empno INT UNSIGNED PRIMARY KEY,
    ename VARCHAR(20) NOT NULL,
    sex ENUM("男", "女") NOT NULL, # 枚举的数据类型,挑选一个
    deptno INT UNSIGNED,
    biredate DATA NOT NULL,
    FOREIGN KEY (deptno) REFERENCES t_dept(deptno)
);

可执行代码

CREATE TABLE t_dept(
    deptno INT UNSIGNED PRIMARY KEY,
    dname VARCHAR(20) NOT NULL UNIQUE,
    tel CHAR(4) UNIQUE
);

CREATE TABLE t_emp(
    empno INT UNSIGNED PRIMARY KEY,
    ename VARCHAR(20) NOT NULL,
    sex ENUM("男", "女") NOT NULL,
    deptno INT UNSIGNED NOT NULL,
    hiredate DATE NOT NULL,
    FOREIGN KEY (deptno) REFERENCES t_dept(deptno)
)

外键约束的闭环问题

  • 如果形成外键闭环,我们将无法删除任何一张表的记录

19

1 views

More from this blog

MySQL | 表的内连接

数据操作语言:表连接查询(一) 从多张表中提取数据 从多张表提取数据,必须指定关联的条件。如果不定义关联条件就会出现无条件连接,两张表的数据会交叉连接,产生 笛卡尔积。 规定了连接条件的表连接语句,就不会出现笛卡尔积。 # 查询每名员工的部门信息 SELECT e.empno,e.ename,d.dname FROM t_emp e JOIN t_dept d ON e.deptno=d.deptno; 表连接的分类 表连接分为两种:内连接 和 外连接 内连接是结果集中只保留符合...

May 16, 20221 min read13
MySQL | 表的内连接

MySQL | 分组查询的应用

数据操作语言:分组查询 为什么要分组? 默认情况下汇总函数是对全表范围内的数据做统计 GROUP BY 子句的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对每个小区域分别进行数据汇总处理 SELECT deptno,AVG(sal) FROM t_emp GROUP BY deptno; SELECT deptno,ROUND(AVG(sal)) FROM t_emp GROUP BY deptno; -- ROUND 取整 逐级分组 数据库支持多列分组条件,执行的时候...

Apr 27, 20221 min read10
MySQL | 分组查询的应用

MySQL | 聚合函数的使用

数据操作语言:聚合函数 什么是聚合函数 聚合函数在数据的查询分析中,应用十分广泛。聚合函数可以对 数据求和、求 最大值 和 最小值 、求 平均值 等等。 求公司员工的评价月收入是多少? SELECT AVG(sal+IFNULL(comm,0)) FROM t_emp; SELECT AVG(sal+IFNULL(comm,0)) AS avg FROM t_emp; SUM 函数 SUM 函数用于求和,只能用户数字类型,字符类型的统计结果为 0 ,日期类型统计结果是毫秒数相加 SE...

Apr 26, 20221 min read8
MySQL | 聚合函数的使用
U

Untitled Publication

173 posts