定义:保证数据库中的数据在逻辑上的一致性、正确性和可靠性。

作用:防止无效数据或错误数据进入数据库

数据完整性包括:实体完整性、域完整性和参照完整性

实体完整性

规定表的每一行记录在表中是唯一的

实体完整性的实现方式包括:主键约束、自增约束、唯一约束

  • 主键约束(Primary Key,PK)用于识别每一条记录,添加主键【右击>设置主键】或者【 alter table表名 add constraint 约束名 primary key(字段名)】;每个数据表只有一个主键,字段内容不能又重复值且不能为空
  • 自增约束(IDENTITIY):【列属性>标识规范】
  • 注意:
  • 有一定的增长规则
  • 只能对整形数据进行设置
  • 不能对自有增约束的字段内容进行输入删除
  • 通常在整型数据的主键上设置自增约束,每次报错都会有一次自增值
  • 唯一约束(Upique):【右击>索引/键>添加】或者【alter table 表名 add constraint 约束名 unique(字段名)】。在一个字段或一组字段中的数据与表中的其他数据想比试唯一的。

注意:主键约束一定是唯一的,而唯一约束不一定是唯一的

域完整性

保证指定列的数据具有正确的数据类型喝有效的数据范围

域完整性的实现方式包括:是否为空、CHECK约束、默认约束

  • 是否为空:not null。保证列中所有数据不能为空
  • CHECK约束:限制字段值的范围【右击>CHECK约束>添加>表达式】或者【alter table 表名 add constraint 约束名 check(内容)】
  • 默认值约束:【列属性>常规>默认值或绑定】或者【alter table 表名 add constraint 约束名 default(默认值) for 字段名】

参照完整性

两表之间的约束,要求一张表的某些列受到另一张表的某列的限制

主表:被参照的表        从表:参照表

主键:主表中被参照的列      外键:从表中的参照列

设置外键:【从表列>右击>关系>添加>表和列规范>设置主键表和外键表>确定】或者【alter table 表名 add constraint 约束名 foreign key(外键字段名) referencese 主表 (关联主键列)】主键表的列名可以和外键表的列名不同)

MYSQL

MySQL不支持检查约束

1.建表时添加约束

CREATE TABLE EMP(

ID  INT  PRIMARY  KEY  auto increment,  --主键约束,auto increment:主键自动增长(当列是数字类型且是唯一约束)

NAME  VACHER(10)  NOT NULL  UNIQUE,  --不为空且唯一,唯一约束

BIRTHDAY DATE  NOT NULL,  --不为空

SALARY  DOUBLE(7,2)  NOT NULL,  --不为空,非空约束

BONUS DOUBLE(7,2)  DEFAULE 0  --如果没有则默认为0,默认约束

)

外键约束

建立两表的数据之间建立链接,保证数据的一致性和完整性

建表时添加约束:CATEATE TABLE 表名(列明 数据类型,...CONSTRAINT  外键名称 FOREIGN KEY 外键列名 REFERNCES 主表列名)

建表后添加约束:alter table 表名 add constraint 约束名 foreign key(外键字段名) referencese 主表 (关联主键列)

2.建表后添加约束

ALTER TABEL 表名 MODIFY 字段名 数据类型 NOT NULL;

3.删除约束

删除非空约束:ALTER TABLE 表名 MODIFY 字段名 数据类型;

删除唯一约束:ALTER TABLE  表名 DROP INDEX 字段名;

删除默认约束:ALTER TABLE 表名 ALTER 列名 DROP DEFAULT;

删除外键约束:ALTER TABEL 表名 DROP FOREIGN KEY 外键名称;

SQL server——基础篇之数据完整性的更多相关文章

  1. SQL Server 基础 02 确保数据完整性

    本章总结目的:    为了巩固 约束.事务! 约 束 使用数据库约束就是保证数据库的完整性的方法,SQL Server 涉及的完整性有三个: 1.实体完整性 : (不能为空且重复,即唯一的,例如身份证 ...

  2. 【SQL Server】SQL Server基础之存储过程

    SQL Server基础之存储过程  阅读目录 一:存储过程概述 二:存储过程分类 三:创建存储过程 1.创建无参存储过程 2.修改存储过程 3.删除存储过程 4.重命名存储过程 5.创建带参数的存储 ...

  3. SQL server基础知识(表操作、数据约束、多表链接查询)

    SQL server基础知识 一.基础知识 (1).存储结构:数据库->表->数据 (2).管理数据库 增加:create database 数据库名称 删除:drop database ...

  4. 数据库开发基础-SQl Server 基础

    SQL Server 基础 1.什么是SQL Server SQL:Structured Query Language  结构化查询语言 SQL Server是一个以客户/服务器(c/s)模式访问.使 ...

  5. Sql Server 基础知识

    Sql Server 基础知识: http://blog.csdn.net/t6786780/article/details/4525652 Sql Server 语句大全: http://www.c ...

  6. Sql Server 基础语法

    来自:http://www.cnblogs.com/AaronYang/archive/2012/04/24/2468093.html Sql Server 基础语法 -- 查看数据表 select  ...

  7. 【目录】sql server 进阶篇系列

    随笔分类 - sql server 进阶篇系列 sql server 下载安装标记 摘要: SQL Server 2017 的各版本和支持的功能 https://docs.microsoft.com/ ...

  8. 【目录】sql server 架构篇系列

    随笔分类 - sql server 架构篇系列 sql server 高可用镜像 摘要: 一.什么是数据库镜像 基本软件的高可用性解决方案 快速的故障转移恢复(3秒转移),低硬件成本 基于数据库级别的 ...

  9. 《SQL Server基础——SQL语句》

    SQL Server基础--SQL语句       一.创建和删除数据库: 1.创建数据库(默认化初始值) 格式: CREATE DATABASE 数据库名称 例如: CREATE DATABASE ...

  10. SQL Server基础之索引

     索引用于快速找出在某个列中有某一特定值的行,不使用索引,数据库必须从第一条记录开始读完整个表,直到找出相关的行.表越大,查询数据所花费的时间越多,如果表中查询的列有一个索引,数据库能快速到达一个位置 ...

随机推荐

  1. pytest 之conftest.py是什么

    conftest.py是pytest框架的固定写法:可以把hook和fixture写在这个文件里,就会自动去调用:conftest.py相当于可以编写自己的插件: 也可以理解为pytest特有的本地测 ...

  2. 【服务器数据恢复】HP EVA存储多块硬盘离线的数据恢复案例

    服务器故障&检测&分析:某品牌EVA存储设备中的RAID5磁盘有两块硬盘掉线,lun丢失.硬件工程师对故障服务器进行物理故障检测,发现掉线硬盘能够正常读取,无物理故障,也没有发现坏道. ...

  3. USB转UART的桥接控制器 国产DPU02软硬件兼容替换CP2102

    DPU02是一个高度集成的USB转UART的桥接控制器,可将RS-232设计更新为USB设计,并简化PCB组件空间.该DPU02包括了一个USB 2.0全速功能控制器.USB收发器.振荡器.EEPRO ...

  4. Centos SSH 免密操作

    1. 在本机生成公钥+私钥      ssh-keygen -t rsa 2. 发送密钥到目标服务器      ssh-copy-id root@192.168.137.111 3.尝试登录目标服务器 ...

  5. JAVA格式化数字

    DecimalFormat df = new DecimalFormat("#.##"); System.out.println(df.format(100.1234)); // ...

  6. Unity旧版图集和新版图集

    1.关于旧版图集 ===>结论:设置PackingTag就可以了. ===>分析:设置好PackingTag,那么在进行打包的时候,同一个标签的会被打到1个图集里面,图集最大为2048x2 ...

  7. 华为交换机,改vlan的方法

    telnet 登录1.1.1.111, 如果登录再到其他交换机,需要在用户状态,telnet其他的ip.不能在系统用户状态下跳转登录. sys改为系统用户  状态符由尖括号,改为方括号 display ...

  8. 配置全局路由表和VRF路由表之间的路由泄漏

    1.拓扑图 2.R1配置 R1#sho run Building configuration... Current configuration : 1360 bytes ! upgrade fpd a ...

  9. vue高级进阶( 一 ) 组件精髓概述

    前言 这个系列可能会分为几部分: 基础以及高级用法总结 一些比较有代表性的实战 源码解析(一定是用最粗俗,不对,是最通俗的语言讲解,这个我可以保证) 总之一定对得起高级进阶这几个字... 组件分类 v ...

  10. <<运算?&=、|=、 ^=、<<=、>>=的意思? 十六进制前缀是 0x。

    <<运算? a<<b 表示把a转为二进制后左移b位(在后面添加 b个0).例如100的二进制表示为1100100,100左移2位后(后面加2个零):1100100<< ...