DBS note7 (end):DB Design

目录

一、前言

二、引言

三、Entity-Relationship Models(实体-关系模型)

1、关系约束

三、函数依赖和正则化

1、BCNF分解

2、无损分解

3、依赖关系保留分解


一、前言

略读过一遍CS186,对于CS186来说,绝对不止这 7 篇笔记(包括这一篇)中呈现的内容,我把我的note 7作为该课程的收尾笔记是因为我目前深究课程里面的部分内容性价比不高,我要把精力花在刀刃上,另一原因是我还没有找到比较好的学习数据库的节奏和方法,这7篇note不是结束,只是开始,虽说没有给我带来很多硬核知识上的领悟,但这给我方向上的指引,日后遇到类似知识,可以在博客进行修订补充,不管怎么说,跌跌撞撞前进总比没有前进来得好。结束这一篇note后,下一篇就是新开课程学习著名神课15-445。下面言归正传。

二、引言

到目前为止,我们已经学会了如何使用已经构建好的数据库:SQL查询。但是,如果我们获得了有关我们想要存储的数据的高级描述,我们该怎么设计一个能满足我们需求的数据库呢?

三、Entity-Relationship Models(实体-关系模型)

在设计数据库时,我们经常使用实体-关系模型(也称为 “E-R” 模型)。这些模型有两个主要组成部分。

第一个主要组成部分是实体:由一组属性值描述的现实世界对象。

在我们的 E-R 模型中,实体通常表示为一个矩形。

此外,与实体关联的属性/字段被描绘为椭圆形。

例如,以下图示显示了员工作为实体在我们的 E-R 模型中,具有以下字段:SSN 号码、姓名和其他信息。请注意,“ssn”属性被加下划线,因为它是该实体的识别属性!在模式中,这将是主键。

第二个主要组成部分是关系:两个或多个实体之间的关联。

在我们的 E-R 模型中,关系通常表示为一个菱形。同样,与关系相关的属性被描绘为椭圆形。例如,以下图示显示了员工和部门之间的 “works in” 关系。"works in" 关系具有属性 "since"。

请注意,相同的实体集可以参与不同的关系集,或者在同一个关系集中扮演不同的 “角色”。

1、关系约束

到目前为止,我们一直用一条细黑线将我们的实体连接到关系。这条线表示多对多的关系。这意味着每个实体可以在关系中参与0次或多次,反之亦然。

例如,对于上面的图表,这意味着许多员工可以在许多部门工作(0次或多次),而部门可以有许多员工(0次或多次)。

相比之下,我们希望我们的模型反映每个部门至多有一个经理。我们通过使用 “键约束” 来实现这一点,该约束表示最多有一个,或者是一对多的关系。键约束由细箭头表示。需要注意箭头的方向,它指向在关系中有 0 或 1 的实体,指向有许多实体的方向。例如,对于以下图表,这意味着每个部门最多有一个经理(0 或 1),而员工可以是许多部门的经理(0 次或多次)。

如果我们希望我们的模型显示每个员工至少在一个部门工作,我们可以使用参与约束,该约束表示至少有一个关系。参与约束由一条粗线表示。例如,在下图中,我们添加了两条粗线。其中一条表示每个员工至少在一个部门工作。另一条表示每个部门至少有一个员工。

此外,可以看到我们添加了一条从部门指向管理者的粗箭头。这既是一个键约束,也是一个参与约束:每个部门恰好有一个经理。

弱实体只能通过考虑另一个(所有者)实体的主键来唯一标识。所有者实体和弱实体必须参与一对多的关系(一个所有者,多个弱实体)。弱实体必须在这个识别关系集中具有总参与度。我们通过加粗矩形和关系来表示弱实体,如下所示。此外,弱实体只有一个 “部分键”(虚线下划线)。在下面的示例中,我们说每个依赖项都通过其 pname 和员工的 ssn 唯一标识,并且每个员工都有 0 个或更多个附属项。

现在我们已经绘制出了我们的 E-R 模型,那么我们如何将其实际组织成关系呢?我们可以将每个实体和关系转化为自己的表,并根据表之间的关系设置主键和外键。一般来说,有很多种方法可以设置关系来表示相同的 E-R 模型。

三、函数依赖和正则化

现在我们已经建立了我们的数据库,我们想要进行优化!我们想要避免的一件事是我们模式中的冗余。这是一种浪费存储空间的情况,同时也会导致插入/删除/更新异常。我们解决这个问题的方法将是函数依赖(Functional Dependencies)。一个函数依赖 X->Y 表示 X 列在表 R 中决定了 Y 列。这意味着对于表 R 中的任意两个元组,如果它们的 X 值相同,那么它们的 Y 值必须相同(但反之则不然)。让我们看几个例子,以更好地理解函数依赖和“决定”是什么意思。在下面的例子中,两行具有相同的 X 值(1),但不同的 Y 值(5和6),因此我们不能说 X 决定了 Y:

对于以下示例,我们可以看到具有相同 X 值的所有行都具有相同的 Y 值。更具体地说,所有 X=1 的行都有 Y=2,所有 X=2 的行都有 Y=4,所有 X=3 的行都有 Y=4。在这种情况下,X 可能确定 Y(即 X->Y):

请注意,在上面的示例中,尽管两行的 Y=4,但它们的 X 值不必相同才能说 X 确定 Y。我们只关心特定 X 值的 Y 值是否相同,反之亦然!主键是函数依赖的特殊情况。超键是一组确定表中所有列的列。如果 X 是表 R 的超键,则 X->R。

候选键是一组列,确定表中的所有列,以至于如果我们移除候选键中的任何列,得到的集合将不是关系的超键。您可以将其视为表的超键的最小列集。如果 X 是 R 的候选键,则 X->R,对于每个严格的子集 Y\subsetX,Y\nrightarrowR。

例如,如果列 K、L 是表中的列,并且 K 是表的主键(即列 K 单独确定表中的所有列),那么 KL 是超键,K 是超键,也是候选键。

我们将使用函数依赖来分解关系以避免冗余。但首先,我们定义 F 的闭包,表示为 F+,是由 F 隐含的所有 FD 的集合。更广泛地说,闭包是可以从已知 FD 推断出的表关系的完整集合。

下面看个例子:

1、BCNF分解

这里只提供一个学习的方向性指引,具体BCNF分解的内容自己去找一下资料,网上很多。

2、无损分解

这里只提供一个学习的方向性指引,具体无损分解的内容自己去找一下资料,网上很多。

3、依赖关系保留分解

这里只提供一个学习的方向性指引。

以上,DBS note7 (end):DB Design

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

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

相关文章

SSM项目实战-登录验证成功并路由到首页面,Vue3+Vite+Axios+Element-Plus技术

1、util/request.js import axios from "axios";let request axios.create({baseURL: "http://localhost:8080",timeout: 50000 });export default request 2、api/sysUser.js import request from "../util/request.js";export const login (…

分布式锁框架Lock4j简单使用

最近项目中使用到了Lock4j的分布式锁组件,小编今天就带大家学习一下该框架,以及如何在我们项目中进行集成使用。 一、简介 Lock4j是一个分布式锁组件,它提供了多种不同的支持以满足不同性能和环境的需求;它基于Spring AOP&#…

SQL Server数据库数据文件的迁移

SQL Server数据库数据文件的迁移 如何将一台电脑中的SQL Server数据库数据文件迁移到另一台电脑上? 一、首先查看数据库文件保存在电脑中的位置; 如下图所示:右键-》属性-》数据库设置;可以找到数据库文件保存位置; …

【Node.js】Node.js环境下载与安装教程(Windows系统)

前言 Node.js是一个基于Chrome V8引擎的JavaScript运行时环境,可以让你使用JavaScript进行服务器端编程。本教程将向你展示如何在Windows系统上下载和安装Node.js环境。 下载 首先,你需要下载Node.js环境。 打开Node.js官方网站:https://no…

Linux系列-1 Linux启动流程——init与systemd进程

背景: 最近对所有项目完成了一个切换,服务管理方式由: init-> systemd。对相关知识进行总结一下。 1.启动流程 服务器的整体启动流程如下图所示: POST: 计算机通电后进行POST( Power-On Self-Test )加电自检&am…

力扣每日一题day26[42. 接雨水]

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。 示例 1: 输入:height [0,1,0,2,1,0,1,3,2,1,2,1] 输出:6 解释:上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] …

MQ - KAFKA 基础篇

##1、KAFKA的核心组件/API Producer API,它允许应用程序向一个或多个 topics 上发送消息记录 Consumer API,允许应用程序订阅一个或多个 topics 并处理为其生成的记录流 Streams API,它允许应用程序作为流处理器,从一个或多个主…

github问题解决(持续更新中)

1、ssh: connect to host github.com port 22: Connection refused 从.ssh文件夹中新建文件名为config,内容为: Host github.com Hostname ssh.github.com Port 4432、解决 git 多用户提交切换问题 使用系统命令ssh创建rsa公私秘钥 C:\Users\fyp01&g…

使用Redis构建简易社交网站(1)-创建用户与动态界面

目的 本文目的:实现简易社交网站中创建新用户和创建新动态功能。(完整代码附在文章末尾) 相关知识 本文将教会你掌握:1.redis基本命令,2.python基本命令。 redis基本命令 hget:从哈希中获取指定域的值…

vitepress的使用

创建项目并启动项目 // 1.创建项目,直接在空项目下安装vitepress(npm/yarn等都可以,这个可以看官网,官网给了好几种安装方式) yarn add -D vitepress // 2.初始化配置项目(npm/官网也给了多种包管理工具的安装方式) npx vitepress init // 初始化命令执行完会遇到以下几个问题…

Python---函数递归---练习:猴子吃桃问题(本文以递归算法 解法为主)

相关链接:Python---函数递归---练习:斐波那契数列(本文以递归算法为主)-CSDN博客 案例:猴子吃桃问题 猴子吃桃问题。猴子第1天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个。…

Web前端监控的方案

Web前端监控的方案 前端监控是一个非常重要的话题,对于业务的发展意义重大,就像遍布在城市各处的探头,实时监测整座城市的运行状况,保证系统的稳定、高效运行。 前端监控的意义 前端监控,对于业务和团队的重要性&am…

Kafka 的起源和背景

Apache Kafka 是一个分布式流处理平台,被广泛用于构建实时数据流应用程序和大数据处理系统。本文将深入探讨 Kafka 的起源、设计原则以及它在大数据领域中的重要作用。 大数据和实时数据处理背景 在大数据时代,处理海量数据和实时数据成为了一项关键挑…

C++学习之路(十七)C++ 用Qt5实现一个工具箱(增加托盘图标并且增加显示和退出菜单)- 示例代码拆分讲解

上篇文章,我们用 Qt5 实现了在小工具箱中添加了《为屏幕颜色提取功能增加一个点击复制的功能》功能。今天我们增加一个比较正式点的功能,就是增加托盘图标并且增加显示和退出菜单(越来越像回事了吧 😁 )。下面我们就来…

Python---函数递归---练习:使用递归求N的阶乘(如n=100)(本文以递归算法 解法为主)

相关链接:Python---函数递归---练习:斐波那契数列(本文以递归算法为主)-CSDN博客 Python---if选择判断结构、嵌套结构(if elif else)_python多重if嵌套-CSDN博客 案例:使用递归求N的阶乘&…

RabbitMQ架构是什么样的

publisher 生产者,发送消息的一方。 consumer 消费者,消费消息的一方。 queue 队列,存储消息。生产者投递的消息会暂存在消息队列中,等待消费者处理。 exchange 交换机,负责消息路由,生产者发送的消息由交换…

ORA-00257: archiver error. Connect internal only, until freed……

今天给客户测 试问题,让客户把数据发过来了。解压缩后一看,他们还是用的oracle 815版本的(他们exp导出时,带了导出日志,从导出日志中看出来是oracle 815版本的),不过没有关系,低版本的exp是可以用高版本的i…

C语言扫雷小游戏

以下是一个简单的C语言扫雷小游戏的示例代码&#xff1a; #include <stdio.h>#include <stdlib.h>#include <time.h>#define BOARD_SIZE 10#define NUM_MINES 10int main() { int board[BOARD_SIZE][BOARD_SIZE]; int num_flags, num_clicks; int …

vmware虚拟机17 安装macos14过程及问题处理亲测

前期准备 1、可引导可虚拟机安装的macOS Sonoma 14 ISO镜像安装文件 我找到得地址&#xff0c;下载自行解决啦 2、VMware虚拟机应用软件 官网下载就好&#xff0c;搜个码搞定 3、解锁工具macOS Unlocker 开始安装&#xff1a; 1、打开VMware软件&#xff0c;新建一个系统…

Sakila数据库和World数据库

Sakila数据库和World数据库 安装MySQL8.2的时候多出两个样例数据库 Sakila数据库和World数据库 Sakila数据库是一个关于DVD租赁的样例数据库&#xff0c;用于展示MySQL的各种功能和特性。Sakila数据库中包含了多个表&#xff0c;包括电影、演员、客户、租赁记录等&#xff0c;可…