四、数据完整性
来源:SegmentFault
时间:2023-01-28 15:16:07 481浏览 收藏
你在学习数据库相关的知识吗?本文《四、数据完整性》,主要介绍的内容就涉及到MySQL,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!
一、什么是数据完整性
数据完整性是指存储在数据库中的数据应该保持一致性和可靠性。关系模型允许定义四类数据约束,分别是:实体完整性、参照完整性、用户定义完整性约束以及域完整性约束。前两个和最后一个完整性约束由关系数据库系统自动支持。
实体完整性
实体是现实世界中的某个对象,在RDBMS中一行数据代表一个实体。实体完整性就是保证每个实体都能被区别。要求每张表都有一个唯一标识符,这个唯一标识符常用的就是主键约束(将某个字段设置为主键),主键字段和不能为空并且不能重复。例如在学生表中学号作为主键,那么我们在插入数据的时候,如果插入的数据的学号和数据表中已存在数据的学号重复的话,将无法插入。对于不是主键字段但是也需要唯一性约束的,我们可以在定义表字段的时候在需要唯一性约束的字段后面加上unique。例如:create table person( id int not null auto_increment primary key comment '主键', name varchar(30) comment '姓名', id_number varchar(18) unique comment '身份编号' );
常用的约束方法包括:唯一性约束、主键约束和标识列。
参照完整性
主要是表与表之间的关系,可以通过外键foregin key来实现。要求关系中不允许引用不存在实体。例如我们有学生表和成绩表,学生表的主键学号字段为成绩表的外键,那么如果我们在成绩表里插入数据的学号在学成表里不存在将无法插入。定义外键的方法如下::#学生表 create table student( stu__no int not null primary key comment '学号', stu_name varchar(30) comment '姓名' ); #成绩表 create table sc( id int not null auto_increment primary key comment '主键', stu_no int not null comment '学号', course varchar(30) commenr '课程', grade int comment '成绩', foreign key(stu_no) references stu(stu_no) #定义外键字段 )
约束方法为:外键约束。
- 用户定义完整性
需要借助存储过程和触发器实现。主要针对某一具体关系数据库的约束条件,反映莫伊具体应用所涉及的数据必须满足语义要求。例如学生表中出生日期不能为1990年以前的日期,当我们插入的数据的出生日期为1990年以前的日期时将无法插入。约束方法为:规则、存储过程和触发器。 域完整性约束
域完整性主要是对列的输入有要求,通过限制列的数据类型、格式或值的范围来实现。是针对某一具体关系数据库的约束条件,它保证表中的某些列不能输入无效值。
例如在学生表中,学号字段定义长度为9位,当插入数据的学号不是9位时就插不进去了。约束方法包括:限制数据类型、检查约束、默认值和非空约束。本文首发平台CSDN,作者博客地址:https://blog.csdn.net/gangzhucoll
理论要掌握,实操不能落!以上关于《四、数据完整性》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!
-
499 收藏
-
244 收藏
-
235 收藏
-
157 收藏
-
101 收藏
-
236 收藏
-
165 收藏
-
188 收藏
-
207 收藏
-
189 收藏
-
366 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习