【数据库原理】(7)关系数据库的完整性约束

关系模型的完整性规则是为了确保数据的唯一性和数据之间的关系的准确性。

有三类完整性约束:实体完整性、参照完整性和用户定义完整性。

其中实体完整性和参照完整性是必须满足的完整性约束条件,应该由关系系统自动支持。

实体完整性

实体完整性的核心概念

  • 唯一性:数据库中的每个元组(行)必须是唯一的,这意味着没有两个完全相同的元组。
  • 主码(主键):为了维护实体的唯一性,每个关系(表)都应该有一个主码,用来唯一标识每个元组。主码是一个或一组不能取空值的属性(字段),它们的组合必须在表中唯一。

实体完整性规则

  • 规则:如果属性(或属性组)A是基本关系R的主码,那么A不能取空值。
  • 含义:主码的每个属性都必须有值,这个值在表中是唯一的,不能重复。

实体完整性的实现

  • 数据库系统的角色:现代的关系数据库管理系统(DBMS)通常会自动执行完整性检查,确保数据符合实体完整性的要求。
  • 用户定义的主码:用户可以定义一个或多个候选码作为主码,DBMS将防止插入具有相同主码的元组。

示例

在这里插入图片描述

以“读者”关系为例,假设图书证编号是主码:

  • 主码唯一性:图书证编号是唯一的,每个读者都有一个不同的图书证编号。
  • 空值问题:主码(图书证编号)不可以为空。任何记录的图书证编号都必须有具体值。

如果图书证编号被设定为主码,那么每个读者的图书证编号都应该是唯一的且不为空。如果有任何图书证编号为空或重复,那么这个表就违反了实体完整性规则。

参照完整性

参照完整性(Referential Integrity)是关系数据库中的一个重要概念,它确保了数据库中不同表之间的逻辑关系的一致性和完整性。以下是对参照完整性的详细解释:

参照完整性的基本概念

  • 定义:参照完整性涉及两个或多个关系(表),确保一个关系中的某个属性(或属性组)的值引用另一个关系的主码。
  • 外码(Foreign Key):在参照关系(从表)中,引用目标关系(主表)主码的属性称为外码。
  • 目标关系与参照关系
    • 目标关系(被参照关系):其主码被另一个关系的外码引用的关系。
    • 参照关系(依赖表):包含引用另一个关系主码的外码的关系。

参照完整性的规则

  • 规则:如果属性(或属性组)F是基本关系R的外码,并且与基本关系S的主码K相对应,则R中的每个元组在F上的值必须满足以下条件之一:
    1. 取空值:即F的每个属性值均为空。
    2. 等于S中某个元组的主码值:即F的值必须是S中存在的主码值。

参照完整性的作用

  • 确保数据一致性:防止数据中出现“悬挂引用”,即参照关系中引用了不存在于目标关系中的主码值。
  • 维护关联数据的完整性:确保数据之间的关系逻辑上是正确的。
  • 操作限制
    1. 插入限制:禁止插入参照关系中存在于目标关系中不存在的外码值。
    2. 更新限制:防止更新目标关系中被引用的主码值,导致参照关系中的外码值成为悬挂引用。
    3. 删除限制:禁止删除目标关系中被参照关系引用的元组。

实例解析

  • 学生与院系关系:学生关系中的“院系编号”是外码,引用院系关系的主码“院系编号”。这保证了每个学生必须属于一个存在的院系。
  • 选课关系:选课关系中的“学号”和“课程号”分别引用学生关系和课程关系的主码,确保每个选课记录都对应一个实际的学生和一个实际的课程。

用户定义完整性

用户定义完整性是关系数据库中的一个重要概念,它允许用户根据具体应用场景的需要设置特定的数据约束。这种灵活性确保了数据库不仅能满足通用的数据完整性规则,还能适应特定的业务规则和逻辑。以下是对用户定义完整性的进一步解释:

用户定义完整性的定义

  • 概念:针对特定应用的关系数据库的特定需求设定的数据约束。
  • 目的:确保数据符合特定应用的逻辑和业务规则。

用户定义完整性的例子

  • 年龄范围:例如,学生的年龄必须在15至75岁之间。
  • 成绩限制:选修课的成绩必须在0到100分之间。
  • 工资增长:更新职工表时,工资和工龄只能增加不能减少。

常见的用户定义完整性约束

  1. 属性空值约束:定义某些属性是否可以为空值。
  2. 属性唯一性约束:确保某些属性(例如,用户ID或电子邮件地址)在数据库中是唯一的。
  3. 属性的取值范围约束:限制属性的取值必须在特定的范围内,例如,工资或年龄。
  4. 属性的默认值设置:为属性定义默认值,用于在未指定值的情况下自动填充。
  5. 属性间的函数依赖关系:定义属性间的逻辑关系,例如,销售额可能取决于销售数量和单价的乘积。

数据库系统的角色

  • 自动化验证:关系数据库系统应能自动验证这些用户定义的完整性约束,而不是依赖于应用程序来实施。
  • 统一处理:提供定义和验证这些约束的机制,以便以一种统一和系统的方式处理它们。

用户定义完整性强化了数据库的能力,使其能够更好地服务于特定的业务逻辑和规则。通过在数据库层面实施这些约束,可以提高数据的质量和可靠性,同时减轻应用程序的负担。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/290463.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【目标检测实验系列】YOLOv5模型改进:融合混合注意力机制CBAM,关注通道和空间特征,助力模型高效涨点!(内含源代码,超详细改进代码流程)

自我介绍:本人硕士期间全程放养,目前成果:一篇北大核心CSCD录用,两篇中科院三区已见刊,一篇中科院四区在投。如何找创新点,如何放养过程厚积薄发,如何写中英论文,找期刊等等。本人后续会以自己实战经验详细…

ElasticSearch自定义算分排序(Function Score Query)

使用 function score query,可以修改文档的相关性算分 (query score),根据新得到的算分排序。 目录 Function Score Query 案例 Function Score Query 几种默认的计算分值的函数: Weight:为每一个文档设置一个简单而不被规范化的权重Fie…

商业综合体能源管理系统功能有哪些?能够为企业带来哪些价值?

随着IT行业的迅猛发展,仅仅实现智能控制已无法满足当前绿色低碳发展的要求,随着智能设备的增多,同时也产生了越来越多的信息孤岛。通过信息技术构建能源管理系统,可以实现先进、智能、经济、可行的商业综合体能源管理解决方案。 …

木工开料机怎么做到减少加工误差的?

在板式家具生产加工中使用木工开料机加工,不仅仅可以提升板材的加工精度,还可以减少板材加工误差,减少板材浪费,所以整个开料环节非常的重要,所以在选择设备的时候一定要谨慎,选择质量可靠的设备。 木工开料…

ssm基于web的网络游戏交易平台信息管理系统的设计与实现论文

摘 要 传统办法管理信息首先需要花费的时间比较多,其次数据出错率比较高,而且对错误的数据进行更改也比较困难,最后,检索数据费事费力。因此,在计算机上安装网络游戏交易平台软件来发挥其高效地信息处理的作用&#x…

HTML5+CSS3+Vue小实例:彩色圆环溶解加载动画

实例:彩色圆环溶解加载动画 技术栈:HTML+CSS+Vue.js 效果: 源码: 【HTML】 <!DOCTYPE html> <html lang="zh-CN"> <head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge&…

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之线性布局容器Column组件

鸿蒙&#xff08;HarmonyOS&#xff09;项目方舟框架&#xff08;ArkUI&#xff09;之线性布局容器Column组件 一、操作环境 操作系统: Windows 10 专业版、IDE:DevEco Studio 3.1、SDK:HarmonyOS 3.1 二、Column组件 沿垂直方向布局的容器。 子组件 可以包含子组件。 接…

力扣hot100 二叉树的右视图 递归

&#x1f468;‍&#x1f3eb; 题目地址 时间复杂度&#xff1a; O ( n ) O(n) O(n) &#x1f60b; AC code /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNode(…

计算机毕业设计------SSM邮件收发管理系统

项目介绍 本项目为基于SSM的邮件收发管理系统&#xff1b; 用户角色包含以下功能&#xff1a; 用户登录,写信给好友,查看收件箱,查看已发送的邮件,草稿箱查看,通讯录设置,个人资料管理等功能。 环境需要 1.运行环境&#xff1a;最好是java jdk 1.8&#xff0c;我们在这个平…

Golang-strconv库学习笔记

前言&#xff1a; strconv库是go官方提供的一个标准包&#xff0c;主要用于字符串相关的处理。通过参考官方文档、中文文档和其他工具&#xff0c;进行学习记录。学习重点是其中的内置方法。 本文分为Atoi&#xff0c;Format系列&#xff0c;Parse系列&#xff0c;Append系列,…

SparkSQL基础解析(三)

1、 Spark SQL概述 1.1什么是Spark SQL Spark SQL是Spark用来处理结构化数据的一个模块&#xff0c;它提供了2个编程抽象&#xff1a;DataFrame和 DataSet&#xff0c;并且作为分布式SQL查询引擎的作用。 我们已经学习了Hive&#xff0c;它是将Hive SQL转换成MapReduce然后提…

众和策略安全可靠:如何区分大盘股和小盘股?大盘股指数有哪些?

股票根据流转盘能够划分为大盘股、中盘股、小盘股这三大类&#xff0c;那么&#xff0c;怎么区别大盘股和小盘股&#xff1f;大盘股指数有哪些&#xff1f;下面众和策略为我们准备了相关内容&#xff0c;以供参考。 怎么区别大盘股和小盘股&#xff1f; 根据个股的市值来区别…

希亦、觉飞、小吉三款婴儿洗衣机大比拼!全方位对比测评

由于年龄幼小的婴儿的皮肤都非常的幼嫩&#xff0c;因此婴儿衣物材质的类型大部分都是采用为纯棉&#xff0c;并且婴儿的衣物不能够与大人的衣物一起进行混洗&#xff0c;容易把细菌感染到宝宝的衣物上&#xff0c;因此很多家庭为了保证宝宝衣服的有效清洁&#xff0c;避免交叉…

自动化测试用例设计粒度

自动化测试用例的粒度指的是测试用例的细致程度&#xff0c;即每个测试用例检查的功能点的数量和范围。 通常&#xff0c;根据测试用例的粒度&#xff0c;可以被分为3种不同的层次&#xff0c;从更低层次的细粒度到更高层次的粗粒度。 第一种&#xff1a;单元测试 - 细粒度 …

使用IDEA创建使用 JDK8 的 2.x.x 版本的 Spring Boot 项目以及 Spring Boot 项目如何修改JDK版本

目录 一、在阿里云上官网上创建项目 二、将 IDEA 中创建项目的源地址修改为阿里云官网 三、创建 3.x.x 的项目之后修改配置降低至 2.7.x 版本和使用 JDK8&#xff08;修改 Spring Boot 的 JDK 版本同理&#xff09; 从上面的 Spring Boot 官网的截图中可以发现&#xff0c;自…

【算法挨揍日记】day34——647. 回文子串、5. 最长回文子串

647. 回文子串 647. 回文子串 题目描述&#xff1a; 给你一个字符串 s &#xff0c;请你统计并返回这个字符串中 回文子串 的数目。 回文字符串 是正着读和倒过来读一样的字符串。 子字符串 是字符串中的由连续字符组成的一个序列。 具有不同开始位置或结束位置的子串&am…

1 电科院FTU检测标准学习笔记-外观检查

作者简介&#xff1a; 本人从事电力系统多年&#xff0c;岗位包含研发&#xff0c;测试&#xff0c;工程等&#xff0c;具有丰富的经验 在配电自动化验收测试以及电科院测试中&#xff0c;本人全程参与&#xff0c;积累了不少现场的经验 目录 **前言****检测大纲****外观与结构…

docker (portainer 安装nginx)

一、创建容器 二、配置端口&#xff0c;以及容器卷挂载 挂载目录配置&#xff1a;(下方截图的目录如下&#xff0c;docker 改为 mydocker&#xff0c;用docker作为根目录不行) /mydocker/nginx/html /usr/share/nginx/html /mydocker/nginx/conf/nginx.conf /etc/nginx/ng…

18|CAMEL:通过角色扮演脑暴一个鲜花营销方案

18&#xff5c;CAMEL&#xff1a;通过角色扮演脑暴一个鲜花营销方案 CAMEL 交流式代理框架 下面我们一起来看看 CAMEL——这个多 AI 通过角色扮演进行交互的框架&#xff0c;以及它在 LangChain 中的具体实现。 CAMEL&#xff0c;字面意思是骆驼。这个框架来自于论文《CAMEL:…

企业微信开发:自建应用:应用形态(网页,小程序,默认页面)

概述 问题&#xff1a; 企业微信&#xff0c;自建应用&#xff0c;应该实现成什么样子&#xff1f;应用里是一个网页应用吗&#xff1f; 企业微信自建应用可以实现为多种形态&#xff0c;根据实际需求和功能设计&#xff0c;它可以是一个网页应用、一个小程序或者结合企业微信提…