我们知道,一种数据模型必须包含三个基本的部分:

  • 构造机制(数据结构):主要描述数据的类型、内容、性质以及数据间的联系等。
  • 运算机制(数据操作):主要描述在相应的数据结构上的操作类型和操作方式。
  • 约束机制(数据约束):主要描述数据结构内数据间的语法、词义联系、他们之间的制约和依存关系,以及数据动态变化的规则,以保证数据的正确、有效和相容。

作为数据库的一种数据模型,关系模型提供了一组完整性规则或限制。完整性约束用于确定关系数据库里数据的准确性和一致性。

在关系型数据库里,完整性约束包括域完整性实体完整性引用完整性以及用户定义完整性

一、完整性约束的概念

1.1 域完整性

域完整性,是指给定列的取值范围(即输入的有效性),比如性别取值应为男或女。

强制域有效性的方法有:限制类型(通过数据类型)、格式(通过 CHECK 约束和规则)或可能值的范围(通过 FOREIGN KEY 约束、CHECK 约束、DEFAULT 定义、NOT NULL 定义和规则)。

1.2 实体完整性

实体完整性,是指使用主键来唯一地标识一个实体。

在关系数据库中,一条记录代表一个实体。而实体是可以相互区分、识别的,也即它们应具有某种唯一性标识(该标识不能取相同的值,也不能为空)。

实体完整性强制表的标识符列或主键的完整性(通过索引、UNIQUE 约束、PRIMARY KEY 约束或 IDENTITY 属性)。

1.3 引用完整性

引用完整性,就是定义外键与主键之间的引用规则。

假设有两个关系:

  1. Student (stuID, name, sex, age, classID);
  2. Class (classID, amount, teacherName);

其中 classID 是关系 Student 的外键,它引用了关系 Class 里的 classID。这个外键确保了关系 Student 里的每个 classID 都在关系 Class 中有对应的 classID。在输入或删除记录时,引用完整性保持表之间已定义的关系:

  • 为了在 Student 中插入一条记录,其 classID 首先要存在于 Class 中。
  • 在 Class 中删除一条记录,则 Student 中 classID 值对应的记录必须全部被删除。

引用完整性基于外键与主键之间或外键与唯一键之间的关系(通过 FOREIGN KEY 和 CHECK 约束)。引用完整性确保键值在所有表中一致。这样的一致性要求不能引用不存在的值,如果键值更改了,那么在整个数据库中,对该键值的所有引用要进行一致的更改。

1.4 用户定义完整性

用户定义完整性让用户可以定义不属于其它任何完整性分类的特定业务规则。所有的完整性类型都支持用户定义完整性(CREATE TABLE 中的所有列级和表级约束、存储过程和触发器)。

二、MySQL中的约束

不同的数据库产品对完整性约束的支持程度不一样,但基本的完整性约束都是支持的。相信以后会越来越完善。

2.1 主键约束

主键,又称主码,是表中一列或多列的组合,能够唯一地标识表中的一条记录。主键约束(Primary Key Constraint)要求主键列的数据唯一,且不允许为空。

在创建表的过程中添加一个字段的主键约束:

  1. CREATE TABLE employees (
  2. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  3. name VARCHAR(20) NOT NULL,
  4. deptId INT(3) NOT NULL,
  5. salary FLOAT NOT NULL
  6. );
  1. CREATE TABLE employees (
  2. id INT(11) AUTO_INCREMENT,
  3. name VARCHAR(20) NOT NULL,
  4. deptId INT(3) NOT NULL,
  5. salary FLOAT NOT NULL,
  6. PRIMARY KEY(id)
  7. );

注意:AUTO_INCREMENT表示自增,默认初始值为1。

也可以使用多个字段的组合作为主键:

  1. CREATE TABLE employees (
  2. name VARCHAR(20) NOT NULL,
  3. deptId INT(3) NOT NULL,
  4. salary FLOAT NOT NULL,
  5. PRIMARY KEY(name, deptId)
  6. );

另外,也可以在建表之后使用ALTER添加主键约束:

  1. CREATE TABLE employees (
  2. name VARCHAR(20) NOT NULL,
  3. deptId INT(3) NOT NULL,
  4. salary FLOAT NOT NULL,
  5. );
  6. ALTER TABLE employees ADD CONSTRAINT emp_pk PRIMARY KEY(name, deptId);

2.2 唯一性约束

唯一性约束(Unique Constraint)要求表里某个字段的值在每条记录里都是唯一的,这一点与主键类似。声明为 UNIQUE 的字段允许为空,但只能出现一个空值。

  1. CREATE TABLE department(
  2. deptId INT(3) PRIMARY KEY,
  3. name VARCHAR(20) UNIQUE,
  4. location VARCHAR(50)
  5. );
  1. CREATE TABLE department(
  2. deptId INT(3) PRIMARY KEY,
  3. name VARCHAR(20),
  4. location VARCHAR(50),
  5. UNIQUE(name)
  6. );

2.3 外键约束

外键(Foreign Key):首先它是表中的一个字段,它可以不是本表的主键,但必须对应另外一个表的主键。外键可以为空值,若不为空值,则每一个外键值必须等于另一个表中主键的某个值。

外键约束是确保表与表之间引用完整性的主要机制。一个表可以有一个或多个外键。通常,我们把外键所在的表称为子表,外键所引用的表称为父表

  1. CREATE TABLE employees(
  2. id INT(11) PRIMARY KEY,
  3. name VARCHAR(20) NOT NULL,
  4. deptId INT(3) NOT NULL,
  5. salary FLOAT NOT NULL,
  6. CONSTRAINT emp_fk FOREIGN KEY(deptId) REFERENCES department(deptId)
  7. );

或者

  1. ALTER TABLE employees ADD CONSTRAINT emp_fk FOREIGN KEY(deptId) REFERENCES department(deptId);

2.4 非空约束

非空约束(Not Null Constraint)指字段的值不能为空。对于使用了 NOT NULL 约束的字段,如果用户在添加数据时没有指定值,数据库系统会报错。

  1. CREATE TABLE employees (
  2. id INT(11) PRIMARY KEY,
  3. name VARCHAR(20),
  4. deptId INT(3),
  5. salary FLOAT
  6. );

添加非空约束:

  1. ALTER TABLE employees MODIFY name varchar(20) NOT NULL;

取消非空,并添加默认值:

  1. ALTER TABLE employees MODIFY name varchar(20) DEFAULT 'abc';

2.5 检查约束

检查约束(Check Constraint)用于检查输入到特定字段的数据的有效性。MySQL不支持check约束,但可以使用check约束,而没有任何效果。

  1. CREATE TABLE employees (
  2. id INT(11) PRIMARY KEY,
  3. name VARCHAR(20),
  4. age INT(3),
  5. CONSTRAINT age_chk CHECK(age>18)
  6. );

上面 check 约束要求 age 必须大于18,但插入数据时却没有起到任何作用。

MySQL基础笔记(二) 完整性约束的更多相关文章

  1. MYSQL基础笔记(二)-SQL基本操作

    SQL基本操作 基本操作:CRUD,增删改查 将SQL的基本操作根据操作对象进行分类: 1.库操作 2.表操作 3.数据操作 库操作: 对数据库的增删改查 新增数据库: 基本语法: Create da ...

  2. MYSQL基础笔记(一)

    关系型数据库概念: 1.什么是关系型数据库? 关系型数据库:是一种建立在关系模型(数学模型)上的数据库 关系模型:一种所谓建立在关系上的模型. 关系模型包含三个方面: 1.数据结构:数据存储的问题,二 ...

  3. MYSQL基础笔记(六)- 数据类型一

    数据类型(列类型) 所谓数据烈性,就是对数据进行统一的分类.从系统角度出发时为了能够使用统一的方式进行管理,更好的利用有限的空间. SQL中讲数据类型分成三大类:1.数值类型,2.字符串类型和时间日期 ...

  4. MYSQL基础笔记(四)-数据基本操作

    数据操作 新增数据:两种方案. 1.方案一,给全表字段插入数据,不需要指定字段列表,要求数据的值出现的顺序必须与表中设计的字段出现的顺序一致.凡是非数值数据,到需要使用引号(建议使用单引号)包裹. i ...

  5. MYSQL基础笔记(三)-表操作基础

    数据表的操作 表与字段是密不可分的. 新增数据表 Create table [if not exists] 表名( 字段名 数据类型, 字段名 数据类型, 字段n 数据类型 --最后一行不需要加逗号 ...

  6. Mysql基础(三):MySQL基础数据类型、完整性约束、sql_mode模式

    目录 2.MySQL基础数据类型.完整性约束.sql_mode模式 1. MySQL常用数据类型 2. 完整性约束 3. MySQL的sql_mode模式说明以及设置 2.MySQL基础数据类型.完整 ...

  7. 数据库02 /MySQL基础数据类型、完整性约束、sql_mode模式

    2.MySQL基础数据类型.完整性约束.sql_mode模式 目录 2.MySQL基础数据类型.完整性约束.sql_mode模式 1. MySQL常用数据类型 MySQL常用数据类型预览 1. 1 数 ...

  8. MySQL基础(二)——DDL语句

    MySQL基础(二)--DDL语句 1.什么是DDL语句,以及DDL语句的作用 DDL语句时操作数据库对象的语句,这些操作包括create.drop.alter(创建.删除.修改)数据库对象. 2.基 ...

  9. MYSQL基础笔记(五)- 练习作业:站点统计练习

    作业:站点统计 1.将用户的访问信息记录到文件中,独占一行,记录IP地址 <?php //站点统计 header('Content-type:text/html;charset=utf-8'); ...

  10. JavaScript基础笔记二

    一.函数返回值1.什么是函数返回值    函数的执行结果2. 可以没有return // 没有return或者return后面为空则会返回undefined3.一个函数应该只返回一种类型的值 二.可变 ...

随机推荐

  1. python爬虫---实现项目(二) 分析Ajax请求抓取数据

    这次我们来继续深入爬虫数据,有些网页通过请求的html代码不能直接拿到数据,我们所需的数据是通过ajax渲染到页面上去的,这次我们来看看如何分析ajax 我们这次所使用的网络库还是上一节的Reques ...

  2. java对比IO和NIO的文件读写性能测试

    1. NIO采用更接近操作系统执行IO的方式:通道和缓存器:顾名思义,数据源的数据由缓存器通过通道进行传输. 2. 在JDK5之后,原始IO系统底层用NIO进行了优化,这可以通过sun公布的源码中找到 ...

  3. HTTP请求头的具体含意

    为你详细解读HTTP请求头的具体含意 | 浏览:5763 | 更新:2012-03-16 16:41 当我们打开一个网页时,浏览器要向网站服务器发送一个HTTP请求头,然后网站服务器根据HTTP请求头 ...

  4. ios 封装sqllite3接口

    2013-03-25 17:41 261人阅读 评论(0) 收藏 举报 // #import <Foundation/Foundation.h> #import "sqlite3 ...

  5. MySQL学习点滴 --分区表

    写在前面:笔者之前也有一些MySQL方面的笔记,其中部分内容来自极客时间中丁奇老师的课程.后经园友提醒,这个做法确实不太好.之后我仍会继续更新一下MySQL方面的学习记录,在自己理解之后用自己的方式记 ...

  6. LeetCode(171) Excel Sheet Column Number

    题目 Related to question Excel Sheet Column Title Given a column title as appear in an Excel sheet, re ...

  7. [第一波模拟\day1\T2]{分班}(divide.cpp)

    [题目描述] 小N,小A,小T又大了一岁了. 现在,他们已经是高二年级的学生了.众所周知,高二的小朋友是要进行文理科分班考试的,这样子的话,三个好朋友说不定就会不分在一个班. 于是三个人决定,都考平均 ...

  8. 初识Web框架

    一.Web框架本质 Python的Web框架分为两类: 通过socket自己写程序,自己处理请求: 基于Wsgi(Web Server Gateway Interface:Web服务网关接口),处理请 ...

  9. CSS小知识点一

    1.   text-indent属性    缩进文本 通过使用 text-indent 属性,所有元素的第一行都可以缩进一个给定的长度,甚至该长度可以是负值.这个属性最常见的用途是将段落的首行缩进,一 ...

  10. POJ 1201 差分方程分析

    POJ 1201 给你N个闭区间.每个区间分别为[ai,bi],你必须在这个区间上至少取ci个不同的整数. 现要求所有区间满足各自的条件. 问最少需要选多少个点. 例如[3,7](3)  [8,10] ...