【数据库系统概论】第5章-数据库完整性

文章目录

    • 引言
    • 5.1 实体完整性
    • 5.2 参照完整性
    • 5.3 用户定义的完整性
    • 5.4 完整性约束命名子句
    • 5.6 触发器

引言

  • 数据库的完整性是指数据的正确性相容性
    正确性:符合现实语义、反映当前实际情况。性别必须为男或女。
    相容性:数据库同一对象在不同关系表中的数据是符合逻辑的。学生所在院系必须是已成立的。
  • 数据库完整性和安全性的区别
    完整性防止数据库中存在不符合语义的数据;安全性防止数据库被恶意破坏和非法存取。
  • 为了维护完整性,DBMS必须实现如下功能

1.提供定义完整性约束的机制
2. 提供完整性检查的方法
3. 进行违约处理

5.1 实体完整性

  1. 定义方法
create table student(sno char(9) primary key, // 在列级定义主码...
);
create table student(sno char(9) ...primary key(sno) // 在表级定义主码
);
create table sc(sno char(9) cno char(10)...primary key(sno,cno) // 多属性主码只能在表级定义主码
);
// 非创建表时创建主码
alter table student 
add constraint PK_STU 
primary key clustered (sno asc)
  1. 完整性检查
    时机:执行insert,或对主码列update时
    方法:全表扫描,一一检查;可建立索引减少时间
  2. 违约处理
    (1)主码值是否唯一,不唯一则拒绝insert或update
    (2)主码的各个属性是否为NULL,有一个为空就拒绝insert或update

5.2 参照完整性

  1. 定义
    Foreign key(cno) references course(cno)
CREATE TABLE SC
(Sno CHAR(9) NOT NULL,
Cno CHAR(4) NOT NULL,
Grade SMALLINTPRIMARY KEY (Sno, Cno)/*表级实体完整性*/
FOREIGN KEY (Sno) REFERENCES Student(Sno)/*表级定义参照完整性*/
FOREIGN KEY (Cno) REFERENCES Course(Cno) 
/*表级定义参照完整性*/
);
  1. 完整性检查
    在这里插入图片描述
  2. 违约处理
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    on delete/update 是对被参照表的属性说明的,也就是主键表(被参照表)的主键列值更新后如何影响外键表的对应记录。
    特别的:NO ACTION是指如果外键表存在对应记录,主键表不能执行动作。

5.3 用户定义的完整性

  1. 定义
    (1)属性上的约束(列级)

    // not null
    CREATE TABLE SC
    (Sno CHAR(9) NOT NULL,
    Cno CHAR(4) NOT NULL,
    Grade SMALLINT NOT NULLPRIMARY KEY (Sno, Cno);
    // unique + not null
    CREATE TABLE DEPT
    (Deptno NUMERIC(2),
    Dname CHAR(9) UNIQUE NOT NULL,
    Location CHAR(10)PRIMARY KEY (Deptno)
    );
    // check
    CREATE TABLE Student
    (Sno CHAR(9) PRIMARY KEY,
    Sname CHAR(8) NOT NULL,
    Ssex CHAR(2) CHECK (Ssex IN ('男',女’) ) ,
    /*性别属性Ssex只允许取'男'或'女' */
    Sage SMALLINT,
    Sdept CHAR(20)
    );
    

    (2)元组上的约束
    元组级的限制(表级约束)可以设置不同属性之间的取值的相互约束条件

    CREATE TABLE Student
    (Sno CHAR(9),
    Sname CHAR(8) NOT NULL,
    Ssex CHAR(2),
    Sage SMALLINT,
    Sdept CHAR(20) default 18// 列默认
    PRIMARY KEY (Sno)CHECK (Ssex='女' OR Sname NOT LIKE 'Ms.%')
    /*定义了元组中Sname和 Ssex两个属性值之间的约束条件*/
    )
  2. 检查时机
    INSERT元组或UPDATE属性值时,
    RDBMS自动检查

  3. 违约处理
    不满足则拒绝执行

5.4 完整性约束命名子句

给约束命名之后,方便删除等

  1. 命名约束
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  2. 修改约束
    在这里插入图片描述

    alter table student add constraint df_sex default ('男') for sex
    

5.6 触发器

  • 格式
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
  • 两个内置临时表,很关键
    在这里插入图片描述
    在这里插入图片描述
    注意书上代码和实际数据库软件的实现不一样。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL 中的 ibdata1 文件过大如何处理?

ibdata1 是什么文件? ibdata1 是InnoDB的共有表空间,默认情况下会把表空间存放在一个名叫 ibdata1的文件中,日积月累会使该文件越来越大。 ibdata1 文件过大的解决办法 使用独享表空间,将表空间分别单独存放。MySQL开启独享表空…

刷新账号密码过期时间——脚本案例

OS账号默认30天密码过期,执行下面脚本刷新密码过期时间。 脚本先是从密码文件中读取用户和密码,再使用passwd命令行修改密码。然后过滤chage -l的关键信息判断密码是否修改成功。最后使用expect脚本对每个用户进行ssh登录并测试,确保…

Flutter 官方状态管理 Provider基本使用

当App的复杂性发展到一定程度,就会出现一个页面中不同深度的子Widget需要共享访问同一个数据状态,甚至不同页面需要共享同一个状态的情况,这时我们可能会想到InheritedWidget。InheritedWidget是 Flutter 中非常重要的一个功能型组件,它提供了一种在 Widget 树中从上到下共…

115基于matlab的用于铣削动力学建模的稳定性叶瓣图分析(stablity lobe)

基于matlab的用于铣削动力学建模的稳定性叶瓣图分析(stablity lobe),程序已调通,可直接运行。 115matlab铣削动力学 (xiaohongshu.com)

生活常识-如何开社保证明(四川)

下载并打开天府市民云APP 注册后登陆 点击社保服务 点击社保证明 点击【四川省社会保险个人社保证明名(近24个月)】 点击下载 下载后点击【QQ发送给好友,然后发送给自己的电脑设备(我的电脑)】

Pthon Request库源码解读之__init__.py

首先我们需要了解下这个文件的功能: init.py 文件在 Python 中有多种用途,但当我们讨论通过 pip 安装的插件或包时,其主要用途是为了确保: 包的结构完整性: 当你尝试导入一个包(文件夹)时&#…

数据类型-变量-内存四区-指针

1、内存四区 1.1、数据类型的本质 1)数据类型基本概念 类型是对数据的抽象类型相同的数据具有相同的表示形式、存储格式、相关的操作程序中使用的数据必定属于某种数据类型数据类型和内存 有关系C/C 引入数据类型,可以更方便地管理数据 2&#xff09…

laravel5.8中实现验证码组件的安装和验证

本篇文章主要讲解使用laravel5.8自带的验证码库实现验证码验证的效果教程。通过本教程你可以快速接入到自己的项目中开发相应的验证功能。 作者:任聪聪 (rccblogs.com) 日期:2023年12月17日 实际效果 安装步骤 步骤一、输入命令 composer require mews…

beego使用布局文件和模板文件进行页面渲染

在 Beego 框架中的控制器基类 Controller 中自定义一个方法,用于渲染模板文件并设置模板数据。 func (this *IndexController) display(tplname string) {this.Layout this.moduleName "/layout.html"this.TplName tplnamethis.LayoutSections make(…

小程序开发与移动应用开发有哪些区别?

小程序开发与移动应用开发:差异何在? 在数字化浪潮下,小程序和移动应用已成为人们日常生活中不可或缺的一部分。但你是否真正了解小程序开发与移动应用开发之间的区别?这篇文章将为你揭开两者之间的神秘面纱。 一、运行环境不同…

不限带宽是否意味着无限带宽

当今互联网发展迅速的时代,带宽成为了网络连接速度的重要指标之一。而对于许多用户来说,无限带宽似乎是一个理想的选择。不限带宽并不等于无限带宽。我将解释不限带宽的含义,并探讨其与无限带宽之间的区别。 不限带宽是指网络服务提供商&…

夸克 自动脚本 每次挖到自动输代码

一个bash脚本,功能是持续运行一个名为`mint-dft`的Yarn CLI命令,并在出现错误时自动重试。 代码解释: 1. `#!/bin/bash`: 这是shebang行,告诉系统使用/bin/bash来解析和执行这个脚本。 2. `export NODE_OPTIONS=--max_old_space_size=49152`: 这一行设置了环境变…

Navicat 年度报告 (2023) | 不忘初心,砥砺前行

#SUMMARY#年度报告 时光荏苒,转眼时间来到 2023 年与 2024 年交汇处。回顾 2023,数据库行业跌宕起伏,暗流涌动。作为数据库工具提供商 Navicat,我们也面临着诸多挑战与压力。一直以来,我们以用户体验为先、技术为本&a…

代理模式:中间者的故事

代理模式:中间者的故事 介绍需求分析代理模式代码实现代理模式整理和用途第一种用途第二种用途第三种用途第四种用途 总结 介绍 本文引用《大话设计模式》第七章节的内容进行学习分析,仅供学习使用 需求:小明拜托自己好朋友小王给他朋友小美…

Swift函数式编程——函数

目录 Swift函数式编程-函数 高阶函数(Higher order function) 一等函数(First class function) 闭包 函数柯里化(Function Curring) 函数式思维 使用函数解决问题 使用函数组合 总结 Sw…

解决IDEA 不能正确识别系统环境变量的问题

问题描述 本人laptop 上的是设置了GOOGLE_APPLICATION_CREDENTIALS 这个环境变量的, 正常java or python 的程序能基于这个环境变量使用 某个gcp service account 去访问GCP的资源 [gatemanmanjaro-x13 ~]$ env | grep -i google GOOGLE_APPLICATION_CREDENTIALS/…

2023年,写博客带给我的收获与成长

文章目录 前言写博客的心路历程膜拜写博客大佬博客大佬带来的诱惑尝试写博客坚持写博客 决定写博客的原因2023年写博客的成就博客的创作粉丝的增长博客专家成就商务合作 2024年对技术写作的展望 前言 没错,我就是那个考试睡大觉、作文空白交卷的王二蛋。面对写作&a…

Tensor轴变换 axis 或 dim(transpose、permute、view、reshape、einsum)

操作分类: 重排维度:transpose、swapaxes、permute都是对维度进行重排序,但不改变维度的大小。 重组维度:view、reshape可以重组原始维度,修改维度大小。 万能运算:einsum 通过操作index(dim/axis)来匹配…

SpringBoot2.7-集成Knife4j

Knife4j 是什么 Knife4j是一个集Swagger2 和 OpenAPI3为一体的增强解决方案 添加依赖 <!--引入Knife4j的官方start包,该指南选择Spring Boot版本<3.0,开发者需要注意--> <dependency><groupId>com.github.xiaoymin</groupId><artifactId>knif…

Django Cookie和Session使用(十一)

一、Cookie Cookie具体指一小段信息&#xff0c;它是服务器发送出来存储在浏览器上的一组键值对&#xff0c;下次访问服务器时浏览器会自动携带这些键值对&#xff0c;以便服务器提取有用信息。 Cookie的特性 1、服务器让浏览器进行设置的 2、保存在浏览器本地&#xff0c;…