从0开始学习mysql 第十四课:数据库设计与三范式

第十四课:数据库设计与三范式

学习目标

在本课中,你将学习关系数据库设计的三个基本范式,它们是用来规范数据库结构,减少数据冗余和改善数据完整性的准则。你将学习:

  • 第一范式(1NF)的概念和实现
  • 第二范式(2NF)的概念和实现
  • 第三范式(3NF)的概念和实现
  • 范式化对数据库性能的潜在影响
  • 通过实例理解如何将这些范式应用到数据库设计中
学习内容
1. 第一范式(1NF)

知识点: 1NF 要求数据库表的每一列都是不可分割的基本数据项,同时每一行都是唯一的。

代码示例:

-- 不符合1NF的表结构
CREATE TABLE Orders (OrderID int,ProductIDs varchar(255)
);-- 符合1NF的表结构
CREATE TABLE Orders (OrderID int,ProductID int
);

预计输出效果:
在符合1NF的设计中,我们需要为每个产品创建新的行,而不是用逗号分隔的字符串来存储多个产品ID。

2. 第二范式(2NF)

知识点: 2NF 在1NF的基础上,要求非主键列必须完全依赖于主键。

代码示例:

-- 不符合2NF的表结构
CREATE TABLE OrderDetails (OrderID int,ProductID int,ProductName varchar(255),OrderDate datetime
);-- 符合2NF的表结构
CREATE TABLE Orders (OrderID int,OrderDate datetime
);CREATE TABLE Products (ProductID int,ProductName varchar(255)
);

预计输出效果:
进行2NF范式化之后,我们将订单数据和产品数据分离到两个表中,每个表都有其自己的主键。

3. 第三范式(3NF)

知识点: 3NF要求数据表中的每一列都只依赖于主键,不能存在传递依赖。

代码示例:

-- 不符合3NF的表结构
CREATE TABLE Orders (OrderID int,CustomerID int,CustomerName varchar(255),CustomerAddress varchar(255)
);-- 符合3NF的表结构
CREATE TABLE Orders (OrderID int,CustomerID int
);CREATE TABLE Customers (CustomerID int,CustomerName varchar(255),CustomerAddress varchar(255)
);

预计输出效果:
在3NF的设计中,订单和客户信息被分离。每个订单引用一个客户ID,而客户的具体信息存储在另一个表中。

范式化对数据库性能的潜在影响

知识点: 范式化可以减少数据冗余和提高数据一致性,但有时也会导致查询性能下降,因为可能需要多个表的JOIN操作。

课后练习
  1. 识别和改正非1NF表:给定一个包含重复行和列的表,将其转换为1NF。
  2. 从1NF到2NF的转换:给定一个1NF表,识别并消除部分依赖,将表升级到2NF。
  3. 从2NF到3NF的转换:给定一个2NF表,识别并消除传递依赖,将表升级到3NF。
  4. 范式化与性能分析:对一个已经范式化的数据库进行性能分析,比较JOIN操作前后的查询效率。

解析:

  1. 识别和改正非1NF表
    原始表可能包含类似以下结构的数据:
CREATE TABLE Sports (PlayerID int,PlayedSports varchar(255)
);

要将此表转换为1NF,需要确保PlayedSports列不包含多个值:

CREATE TABLE Sports (PlayerID int,PlayedSport varchar(255)
);
  1. 从1NF到2NF的转换
    在1NF表中,如果存在一个复合主键,并且某些列只依赖于复合主键的一部分,就需要将这些列移动到新表中:
-- 原始1NF表
CREATE TABLE ClassAssignments (TeacherID int,ClassID int,AssignmentDate date,AssignmentName varchar(255)
);-- 转换为2NF
CREATE TABLE Teachers (TeacherID int,AssignmentName varchar(255)
);CREATE TABLE Classes (ClassID int,TeacherID int,AssignmentDate date
);
  1. 从2NF到3NF的转换
    在2NF表中,如果存在非主键列之间的依赖,需要创建新表来消除这种依赖:
-- 原始2NF表
CREATE TABLE Employees (EmployeeID int,ManagerID int,ManagerName varchar(255)
);-- 转换为3NF
CREATE TABLE Employees (EmployeeID int,ManagerID int
);CREATE TABLE Managers (ManagerID int,ManagerName varchar(255)
);
  1. 范式化与性能分析
    分析可能涉及执行SQL查询并使用EXPLAIN语句来查看查询计划,比较不同设计下的查询复杂性和响应时间。

通过这些练习,你将能够实际操作和理解范式化在数据库设计中的应用及其对性能的影响。

第十五课:数据库事务

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

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

相关文章

知识产权管理

内容: 狭义---著作权,领接权,专利权,商标权 广义---著作权,领接权,专利权,商标权及商业秘密权,防止不正当竞争权,植物新品种权,集成电路布图设计圈、地理标志…

springboot整合MongoDB实战

目录 环境准备 引入依赖 配置yml 注入mongoTemplate 集合操作 文档操作 创建实体 添加文档 查询文档 更新文档 删除文档 环境准备 引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-da…

epoll接口

B站就业班视频代码搬运 p54 但是我跟老师的代码还是有点区别。。老师那里居然ev复用。。那么数组里那些结构体都用不上&#xff1f;&#xff1f; 注意&#xff0c;本篇不是epoll反应堆。 I/O多路复用一共有select , poll ,epoll等模型&#xff0c;但是真正的高并发的话是epo…

优先级队列(堆)详解

优先级队列&#xff08;堆&#xff09;详解 目录 堆的概念堆的存储方式堆的基本操作优先级队列模拟实现PriorityQueue接口介绍堆排序Top-k问题 1、堆的概念 如果有一个关键码的集合K {k0&#xff0c;k1&#xff0c; k2&#xff0c;…&#xff0c;kn-1}&#xff0c;把它的所…

安卓ADB实操教程:以三星Galaxy S10为例

引言 ADB&#xff08;Android Debug Bridge&#xff09;是一个功能强大的命令行工具&#xff0c;它允许用户与安卓设备进行通信以便进行各种操作&#xff0c;包括安装和调试应用程序&#xff0c;访问设备的shell等。本教程将以三星Galaxy S10为例&#xff0c;详细介绍如何使用…

SAP 五个报废率设置简介(上)

通常在生产制造过程中都会面临报废率的问题,生产工艺路线的问题,原材料质量的问题,总会有一些产品在生产过程中被做成报废品,通常报废率的设置有时候会遵循行业的标准设置,亦或者根据工厂生产中统计的历史数据分析后根据不同的产品设置不同的报废率,从而在执行物料的采购…

VM下Unbunt虚拟机上网设置

系列文章目录 VM下虚拟机上网设置 VM下虚拟机上网设置 右击VM软件中你需要设置的虚拟机&#xff0c;选择设置 宿主机如果你用的是笔记本外加WIFI连接选择NAT网络模式 进入虚拟机看能否上网 不行的话&#xff0c;进入虚拟机点击&#xff0c;选择最后一栏&#xff0c;编辑连接 点…

华为认证的HCIP考实验考试么?

HCIP在考试的时候不考实验&#xff0c;只考笔试&#xff0c;只是不同方向的HCIP认证考试的考试科目不同&#xff0c;有的考一科&#xff0c;有的考二科&#xff0c;有的考三科&#xff0c;具体看方向来定。HCIA和HCIP只考笔试。HCIE考笔试和实验。 虽然HCIP不考实操&#xff0…

《WebKit 技术内幕》学习之七(1): 渲染基础

《WebKit 技术内幕》之七&#xff08;1&#xff09;&#xff1a; 渲染基础 WebKit的布局计算使用 RenderObject 树并保存计算结果到 RenderObject 树。 RenderObject 树同其他树&#xff08;如 RenderLayer 树等&#xff09;&#xff0c;构成了 WebKit 渲染的为要基础设施。 1…

【数据结构】链表(单链表与双链表实现+原理+源码)

博主介绍&#xff1a;✌全网粉丝喜爱、前后端领域优质创作者、本质互联网精神、坚持优质作品共享、掘金/腾讯云/阿里云等平台优质作者、擅长前后端项目开发和毕业项目实战✌有需要可以联系作者我哦&#xff01; &#x1f345;附上相关C语言版源码讲解&#x1f345; &#x1f44…

python04-变量命名规则

python需要使用标识符来给变量命名。 标识符&#xff0c;我来解释下&#xff0c;就是给程序中变量、类、方法命名的符号&#xff0c;简单理解就是起一个名字&#xff0c;这个名字必须是合法的名字&#xff0c; 对于Python来说&#xff0c;标识符必须是以字母、下划线(_)开头&…

鸿蒙自定义刷新组件使用

前言 DevEco Studio版本&#xff1a;4.0.0.600 1、RefreshLibrary_HarmonyOS.har&#xff0c;用于HarmonyOS "minAPIVersion": 9, "targetAPIVersion": 9, "apiReleaseType": "Release", "compileSdkVersion": "3.…

用户画像系列——在线服务调优实践

前面文章讲到画像的应用的几个方面&#xff0c;其中画像的在线服务应用主要是在推荐场景、策略引擎场景&#xff0c;这两部分场景都是面向线上的c端服务。 推荐场景&#xff1a;根据不同的用户推荐不同的内容&#xff0c;做到个性化推荐&#xff0c;需要读取画像的一些偏好数据…

openssl3.2/test/certs - 008 - root-nonca trust variants: +serverAuth +anyEKU

文章目录 openssl3.2/test/certs - 008 - root-nonca trust variants: serverAuth anyEKU概述笔记END openssl3.2/test/certs - 008 - root-nonca trust variants: serverAuth anyEKU 概述 openssl3.2 - 官方demo学习 - test - certs 笔记 // \file my_openssl_win_log_doc…

20240123----重返学习-原生js纯函数获取用户电脑上的文件

20240123----重返学习-原生js纯函数获取用户电脑上的文件 思路说明 通过外加点击后&#xff0c;通过监听这个DOM元素的change事件&#xff0c;在用户点击之后就能拿到用户电脑上的文件了。通过原生js来动态创建type"file"的input元素&#xff0c;之后给监听该元素的…

【方法】如何把Excel“只读方式”变成可直接编辑?

Excel在“只读方式”下&#xff0c;编辑后是无法直接保存原文件的&#xff0c;那如何可以直接编辑原文件呢&#xff1f;下面来一起看看看吧。 如果Excel设置的是无密码的“只读方式”&#xff0c;那在打开Excel后&#xff0c;会出现对话框&#xff0c;提示“是否以只读方式打开…

生成随机数C++

随机数生成 在C中&#xff0c;有多种方式可以生成和输出随机数。以下是几种常见的方式&#xff1a; 1. 使用 <cstdlib> 头文件中的 rand() 函数&#xff1a; #include <iostream> #include <cstdlib> #include <ctime>int main() {// 设置种子&…

什么是甘特图?谁还不知道?做管理的来看看!

在现代商业社会&#xff0c;项目管理已成为不可或缺的技能。而甘特图作为一种强大的项目管理工具&#xff0c;正逐渐受到越来越多人的青睐。那么&#xff0c;什么是甘特图&#xff1f;又有什么工具可以绘制甘特图呢&#xff1f;本文将为你一一解答。 一、甘特图的定义 甘特图…

gin会话控制篇 - Cookie和Session

1. Cookie介绍 HTTP是无状态协议&#xff0c;服务器不能记录浏览器的访问状态&#xff0c;也就是说服务器不能区分两次请求是否由同一个客户端发出Cookie就是解决HTTP协议无状态的方案之一&#xff0c;中文是小甜饼的意思Cookie实际上就是服务器保存在浏览器上的一段信息。浏览…

Unity - 简单音频视频

“Test_04” 音频 使用AudioTest脚本控制Audio Source组件&#xff0c;在脚本中声明"music"和"se"之后&#xff0c;在unity中需要将音频资源拖拽到对应位置。 AudioTest public class AudioTest : MonoBehaviour {// 声明音频// AudioClippublic AudioC…