0. 前言

1. 实体完整性

  • 1.1 主键约束(primary key)
  • 1.2 唯一约束(unique)
  • 1.3 自动增长列(auto_increment)

2. 域完整性

  • 数据类型
  • 非空约束
  • 默认值约束

3. 引用完整性

4. 表间的映射关系

0. 前言

什么是数据完整性:保证用户输入的数据能正确地保存到数据库中。

如何确保数据完整性:在创建表时给表中添加约束

完整性的分类:

  1. 实体完整性
  2. 完整性
  3. 引用完整性

1. 实体完整性

什么是实体:表中的一行(一条记录)代表一个实体(entity)。

实体完整性的作用:标识每一行数据不重复。

约束类型:

  1. 主键约束(primary key)
  2. 唯一约束(unique)
  3. 自动增长列(auto_increment)

每个表可以有多个 UNIQUE 约束,但只能有一个 PRIMARY KEY 约束

1.1 主键约束(primary key)

特点:数据唯一,且不能为 null。

-- 第一种添加方式
CREATE TABLE student_1(
     id int primary key,
     name varchar(50)
); -- 第二种添加方式:此种方式优势在于可以创建联合主键
CREATE TABLE student_2_1(
     id int,
     name varchar(50),
     primary key(id)
); CREATE TABLE student_2_2(
     classid int,
     stuid int,
     name varchar(50),
     primary key(classid,stuid)
); -- 第三种添加方式
CREATE TABLE student_3(
     id int,
     name varchar(50)
);
ALTER TABLE student ADD PRIMARY KEY (id);

1.2 唯一约束(unique)

特点:数据不能重复。

CREATE TABLE student(
     id int primary key,
     name varchar(50) unique
);

1.3 自动增长列(auto_increment)

-- 给主键添加自动增长的数值,列只能是整数类型,且必须配合主键使用
CREATE TABLE student(
     Id int primary key auto_increment,
     Name varchar(50)
); INSERT INTO student(name) values('tom');

2. 域完整性

域代表当前单元格。

域完整性的作用:限制此单元格的数据正确,不对照此列的其它单元格比较。

域完整性的约束分类:

  1. 数据类型
  2. 非空约束(not null)
  3. 默认值约束(default)
  4. check 约束(mysql 不支持):check(sex='男' or sex='女')

数据类型

《MySQL 基础、安装、配置》

非空约束(not null)

CREATE TABLE student(
     Id int pirmary key,
     Name varchar(50) not null,
     Sex varchar(10)
); INSERT INTO student values(1, 'tom', null);

默认值约束(default)

CREATE TABLE student(
     Id int pirmary key,
     Name varchar(50) not null,
     Sex varchar(10) default '男'
); insert into student1 values(1, 'tom', '女');
insert into student1 values(2, 'jerry', default);
insert into student1 values(3, 'peter');

3. 引用完整性(外键约束)

在设置外键(FOREIGN KEY)约束的情况下,插入表 2 的外键字段值必需要求在表 1 的主键字段值中能找到。

同时,假设要删除表 1 的某个主键字段值,那么必须保证表 2 中的外键字段没有该主键字段的值,否则就没法删除。

-- 创建表1
CREATE TABLE student(
     sid int pirmary key,
     name varchar(50) not null,
     sex varchar(10) default '男'
); -- 创建表2
-- 第一种添加外键方式
create table score(
  id int,
  score int,
  sid int , -- 外键列的数据类型一定要与主表主键的类型一致
  CONSTRAINT fk_score_sid foreign key (sid) references student(id)
); -- 第二种添加外键方式
ALTER TABLE score ADD CONSTRAINT fk_stu_score FOREIGN KEY(sid) REFERENCES stu(id);

4. 表间的映射关系

示例:

一对一

例如 t_person 表和 t_card 表,即人和身份证。这种情况需要找出主从关系,即谁是主表,谁是从表。人可以没有身份证,但身份证必须要有人才行,所以 t_person 是主表,而 t_card 是从表。

设计从表可以有两种方案:

  • 在 t_card 表中添加外键列(相对 t_person 表),并且给外键添加唯一约束;
  • 给 t_card 表的主键添加外键约束(相对 t_person 表),即 t_card 表的主键也是外键。

一对多(多对一)

最为常见的就是一对多。一对多和多对一,取决于哪个角度去看的,一般都是在多方的那张表创建外键。

多对多

例如 t_stu 和 t_teacher 表,即一个学生可以有多个老师,而一个老师也可以有多个学生。这种情况通常需要创建中间表来处理多对多关系,例如可以再创建一张表 t_stu_tea 表,给出两个外键,一个是相对 t_stu 表的外键,另一个是相对 t_teacher 表的外键。

MSQL 数据完整性(约束)的更多相关文章

  1. enmo_day_06

    RAC Data Guard (DG) EMC NAS SAN 双活 数据完整性 约束 : 主键 : 非空 且 唯一 非空 : 唯一 : 外键 : 检查 : DISABLE, ENABLE VALID ...

  2. oracle学习笔记(转)

    命令行操作:打开服务: services.msc启动Oracle: net start OracleOraHome92TNSListener     net start OracleService实例 ...

  3. MySQL技术内幕读书笔记(四)——表

    目录 表 索引组织表 InnoDB逻辑存储结构 INNODB行记录格式 INNODB数据页结构 约束 视图 分区表 表 ​ 表就是关于特定实体的数据集合,是关系型数据库模型的核心. 索引组织表 ​ 在 ...

  4. SQL Server 2005 中的分区表和索引

    SQL Server 2005 中的分区表和索引 SQL Server 2005          69(共 83)对本文的评价是有帮助 - 评价此主题   发布日期 : 3/24/2005 | 更新 ...

  5. SQL Server 数据完整性的实现——约束

    SQL Server数据库采用的是关系数据模型,而关系数据模型本身的优点之一就是模型本身集成了数据完整性.作为模型一部分而实施的数据完整性(例如在创建数据表时的列属性定义)称作为声明式(Declara ...

  6. MySQL数据库:数据完整性及约束的应用

    数据完整性 1.域完整性:---------匹配完整性:非空.缺省 字段/列 2.实体完整性:-------匹配完整性:主键.唯一键 记录/行 3.引用完整性:-------匹配完整性:外键 表与表之 ...

  7. T-SQL :SQL Server 定义数据完整性 6大约束(三)

    1.创建一客户张表 IF OBJECT_ID('dbo.Employees', 'U') IS NOT NULL DROP TABLE dbo.Employees; CREATE TABLE dbo. ...

  8. Oracle 数据完整性与约束机制

    为了维护数据库数据的完整性,在创建表时需要定义一些约束,Oracle中的约束类型包括:非空约束.主键约束.唯一约束.外键约束等.在对约束操作前,我们可以通过表名查询它具有的约束信息. 表约束 SELE ...

  9. 【第三章】MySQL数据库的字段约束:数据完整性、主键、外键、非空、默认值、自增、唯一性

    一.表完整性约束 作用:用于保证数据的完整性和一致性==============================================================约束条件  说明PRIM ...

随机推荐

  1. 2021S软件工程——结对项目第一阶段

    # 2021S软件工程--结对项目第一阶段 2021春季软件工程(罗杰 任健) 项目地址 1020 1169 --- ## 1 结对感受 总体来说,结对编程与之前的个人编程感觉有很大的不同.有如下几个 ...

  2. 从苏宁电器到卡巴斯基第30篇:难忘的三年硕士时光 VIII

    自给自足 临近毕业答辩,别的导师的学生基本上都完成了各自的论文,也都开始交由第三方进行审核.而我们导师由于情况特殊,还没有机会看我们的论文,所以我们也打算和老师约一个时间,来给我们的论文提点意见,修改 ...

  3. POJ3228二分最大流

    题意:       有n个点,每个点有两个权值,金子数量还有仓库容量,金子可以存在自己的仓库里或者是别的仓库里,仓库和仓库之间有距离,问所有金子都必须存到库里最大距离的最小是多少? 思路:       ...

  4. windows-API劫持(API-HOOK)

    API Hook ApiHook又叫做API劫持,也就是如果A程序调用了B.cll里面的C函数,我们可以做到当A调用C函数执行的时候,直接执行我们自己事先准备好的函数,之后我们在执行真正的C,当然我们 ...

  5. 删除自定义服务 寒江孤钓<<windows 内核安全编程>> 学习笔记

    书中第一章 成功启动first服务之后, 发现书中并没有介绍删除服务的方式, SRVINSTW工具中的移除服务功能,也无法找到我们要删除的服务, 于是,搜素了下,发现解决方法如下: 在cmd中输入 & ...

  6. 分布式事务与Seate框架(1)——分布式事务理论

    前言 虽然在实际工作中,由于公司与项目规模限制,实际上所谓的微服务分布式事务都不会涉及,更别提单独部署构建Seata集群.但是作为需要不断向前看的我,还是有必要记录下相关的分布式事务理论与Seate框 ...

  7. QQ可以登录,网页无法访问

    之前以为是网络的问题,但是,后来发现QQ却可以登录,这是第二次碰到这个情况,所以总结一下 一般我们电脑上都会安装一个杀毒软件,比如火绒等等.我电脑上用的联想自带的电脑管家 我们可以在工具箱中找到网络诊 ...

  8. Web安全之PHP反序列化漏洞

    漏洞原理: 序列化可以将对象变成可以传输的字符串,方便数据保存传输,反序列化就是将字符串还原成对象.如果web应用没有对用户输入的反序列化字符串进行检测,导致反序列化过程可以被控制,就会造成代码执行, ...

  9. 01 CTF MISC 杂项 知识梳理

    1.隐写术( steganograhy ) 将信息隐藏到信息载体,不让计划的接收者之外的人获取信息.近几年来,隐写术领域已经成为了信息安全的焦点.因为每个Web站点都依赖多媒体,如音频.视频和图像.隐 ...

  10. 优雅地使用命令行:Tmux 终端复用

    转自:http://harttle.com/2015/11/06/tmux-startup.html 你是否曾经开过一大堆的Terminal?有没有把它们都保存下来的冲动?Tmux 的Session就 ...