【面试小姿势】数据库设计的三大范式及其应用

news2024/11/27 9:45:59

前言:
今天和大家探讨一道最近的面试题,面试回答描述的不是很清楚,所以在此记录一下。本篇文章主要讲解Java类加载机制的知识。该专栏比较适合刚入坑Java的小白以及准备秋招的大佬阅读。

如果文章有什么需要改进的地方欢迎大佬提出,对大佬有帮助希望可以支持下哦~

小威在此先感谢各位小伙伴儿了😁

在这里插入图片描述

以下正文开始

在这里插入图片描述

文章目录

  • 面试ing~
  • 第一范式(1NF)
  • 第二范式(2NF)
  • 第三范式(3NF)
  • 小结
  • 图书推荐

面试ing~

面试官:数据库中,在创建表时需要注意什么?
我:需要合理的创建索引和使用索引,balabala,开始吟唱…
面试官:除了索引呢?
我:在创建字段时,应注意字段合理使用char和varchar定义,需要满足三大范式(好久没看,没忽悠住面试官)
给自己挖了大坑…

现在来填补一下这个大坑!

在这里插入图片描述

第一范式(1NF)

第一范式要求数据库表中的每个字段都是原子性的,不可再分。换句话说,就是每个字段中不能包含多个值或重复的数据。此外,每个表必须具有唯一的标识符(主键),用来唯一地标识每一行。

比方说我们现在有一个存储顾客订单的数据库表,如果我们将顾客姓名和联系方式拆分成多个字段,就违反了第一范式。合理的做法是将每个顾客的信息存储为一行,并且为每一行添加一个唯一的标识符。

-- 错误定义(违反第一范式)
CREATE TABLE Orders (
    OrderId INT PRIMARY KEY,
    CustomerFirstName VARCHAR(50),
    CustomerLastName VARCHAR(50),
    CustomerPhone VARCHAR(20)
)

-- 正确定义
CREATE TABLE Orders (
    OrderId INT PRIMARY KEY,
    CustomerName VARCHAR(100),
    CustomerPhone VARCHAR(20)
)

第二范式(2NF)

第二范式要求数据库表中的非主键字段完全依赖于主键,而不是依赖于主键的一部分。换句话说,如果某个字段与主键只有部分依赖关系,就需要将其拆分到另一个表中。

比如,我们有一个订单表,订单表包含的字段如下:
在这里插入图片描述

这个表格中的字段就违反了第二范式,因为"类别"字段只与"产品"字段相关,而与主键"订单号"无关。我们把它拆分为两个表格就对了,如下所示:

订单表:
在这里插入图片描述
产品表:
在这里插入图片描述

第三范式(3NF)

第三范式要求数据库表中的非主键字段之间没有传递依赖关系。换句话说,如果一个字段可以通过其他非主键字段推导出来,就需要将其拆分到另一个表中。

以一个学生表为例,现在有以下字段,是不符合数据库第三范式的:
在这里插入图片描述
因为"教师"字段依赖于"课程"字段,而非主键"学号"。需要将它拆分为三个表格:

学生表:
在这里插入图片描述
课程表:
在这里插入图片描述

成绩表:

在这里插入图片描述

这样分表才符合数据库的第三大范式!.

在这里插入图片描述

小结

数据库的三大范式(1NF、2NF和3NF)给我们提供了一套指导原则,帮助我们用于设计高效、规范的关系型数据库。

第一范式确保每个字段都是原子性的,每个表具有唯一标识符;第二范式消除了非主键字段对主键的部分依赖;第三范式消除了非主键字段之间的传递依赖。

遵循数据库的范式的优点:

可以帮助我们设计出更加规范、高效的数据库结构,减少数据冗余、提高数据一致性,并减少数据更新异常的风险。

But,根据具体的业务需求,在某些情况下可能需要权衡范式的规则来满足特定的性能或灵活性需求。所以在数据库设计中,根据实际情况选择合适的范式还是非常重要滴~~~。

在这里插入图片描述

图书推荐

在这里插入图片描述

清华社【秋日阅读企划】领券立享优惠

IT好书 5折叠加10元 无门槛优惠券:点击领取

活动时间:9月4日-9月17日,先到先得,快快来抢

在这里插入图片描述
比较适合小白的MySQL数据库书籍,内容很不错,是32万数据库开发人员的首选。

京东直售五折链接:点我查看详情

文章到这里就先结束了,感兴趣的可以订阅专栏哈,后续会继续分享相关的知识点。

在这里插入图片描述

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

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

相关文章

扩展pytest接口自动化框架-MS数据解析功能

开篇 MeterSphere的数据源通过html页面上传后,需要将请求方式进行拆分。 get接口的参数,常以params的方式进行传参,也就是在url后带上参数。 post接口一般是以json字符串的形式传参,也有params方式进行传参的。而在MeterSphere里…

三方检测-渗透测试问题及问题处理

文章目录 省流具体问题信息遍历【高风险】描述举例解决方案 任意文件上传【高风险】描述解决方案 邮箱验证码等轰炸【中风险】描述解决方案 用户名轰炸【高风险】描述解决方案 错误信息返回敏感信息【高风险】描述举例解决方案 明文传输漏洞【高风险】描述举例解决方案 点击劫持…

优思学院|防呆防错的英语怎么说?

许多学生都曾经问过一个常见而有趣的问题:防呆的英文究竟是什么?他们之所以感到困惑,是因为在不同的场合听到了很多不同的表述,比如Mistake Proofing、Error Proofing、Fool Proofing等等。在本文中,我们将详细解答这个…

ArcMap对遥感图像进行语义分割标注

创建工程 新建一个空白地图 右键图层,点击添加数据,导入要标注的遥感图像 创建shp文件 右键点击导入的遥感图像,查看属性,找到遥感图像的XY坐标系,复制坐标系名称 点击窗口->目录 3. 右键点击文件夹&#xff0c…

抽奖小程序源码:多功能萝卜抽奖系统微信小程序抽奖功能源码【更新】

小程序源码介绍 萝卜抽奖是一款微信小程序,里面有很多好玩的抽奖活动。你可以自由地在它的五种不同风格的首页模板之间切换。 这个小程序非常实用,支持各种优惠券领取,包括外卖和电商的优惠券。而且,它还提供砍价、抢购、九宫格…

嵌入式学习笔记(30)S5PV210的中断体系介绍

6.4.1什么是中断? (1)中断的发明是用来解决宏观上的并行需要的。宏观就是从整体来看,并行就是多件事情都完成了。 (2)微观上的并行,就是指的真正的并行,就是精确到每一秒甚至每一刻…

【HMS Core】华为地图服务调用接口403问题

【关键字】 HMS、地图服务、403 【问题描述】 有开发者反馈在集成地图服务与企业版地图服务,使用js模式,能正常加载地图,但是调用接口siteService.searchByText(request, function (result, status) 返回Status Code:405 返回结果returnCod…

2023Web前端面试题及答案(一)

答案仅供参考,每人的理解不一样。 文章目录 1、简单说一说事件流原理 事件流: (1)事件流是指页面 接收事件的顺序; (2)假设页面中的元素都具备相同的事件,并且这些个元素之间是相互嵌套的 关系. (3&#xf…

3款免费的录屏软件推荐,轻松录制高质量视频

在现代社会,录屏软件已经成为了许多人工作和生活的必备工具。无论是教学、演示、游戏还是娱乐,录屏软件都能为我们带来极大的便利。然而,市面上的许多录屏软件往往价格高昂,令人望而却步。因此,本文将为大家推荐几款免…

ROS从入门到精通2-8:Gazebo仿真之快速生成二维地图真值

目录 0 专栏介绍1 为什么需要地图真值?2 Gazebo插件实现2.1 单线扫描碰撞信息2.2 写入.pgm地图文件2.3 写入.yaml元文件 3 快速建图测试4 机器人导航测试 0 专栏介绍 本专栏旨在通过对ROS的系统学习,掌握ROS底层基本分布式原理,并具有机器人…

java项目之家用电器销售网站(源码+文档)

风定落花生,歌声逐流水,大家好我是风歌,混迹在java圈的辛苦码农。今天要和大家聊的是一款基于ssm的家用电器销售网站。项目源码以及部署相关请联系风歌,文末附上联系信息 。 💕💕作者:风歌&…

防火墙概述及实战

目录 前言 一、概述 (一)、防火墙分类 (二)、防火墙性能 (三)、iptables (四)、iptables中表的概念 二、iptables规则匹配条件分类 (一)、基本匹配条…

uniapp如何实现路由守卫、路由拦截,权限引导

因为uniapp路由的实现方式和以往vue开发的router路由时不太一样,故官方这么说: 经过一番网上冲浪发现,有两种方式可以实现, 第一种方式: 在上述代码中,我们通过监听beforeRouterEnter事件来实现路由守卫。…

TypeScript解读TSConfig

🎬 岸边的风:个人主页 🔥 个人专栏 :《 VUE 》 《 javaScript 》 ⛺️ 生活的理想,就是为了理想的生活 ! 目录 创建和基本配置 compilerOptions target module outDir strict lib sourceMap paths allowJs esModuleIn…

10_光速学会docker用法:80分钟一口气学完docker+k8s!带你掌握docker+k8s所有核心知识点,全程干货,无废话!

启动第一个docker容器 #1、获取镜像 #2、运行镜像,生成容器,应用就跑在了容器中。 Nginx web服务器,运行处一个80端口的网站 #在宿主机上,运行Nginx 1、开启服务器 2、在服务器上安装好运行Nginx所需的依赖关系 3、安装nginx …

Allegro如何导出带有钻孔数据的dxf文件?

在Allegro软件中,导出带有钻孔数据的DXF文件是一个常见的任务,特别是需要将涉及文件与其他CAD工具或PCB制造商共享时,所以下面将谈谈,如何在Allegro软件中导出带有钻孔数据的dxf文件。 1、打开设计文件 首先,打开Alle…

RISC Zero zkVM 白皮书

1. 引言 RISC Zero提供了开源的虚拟机零知识证明系统,即zero-knowledge virtual machine(简称zkVM)。当在zkVM中执行某RISC-V二进制文件时,其输出为: 二进制文件执行结果+ 一个computational receipt&…

Unity中程序集dll

一:前言 一个程序集由一个或多个文件组成,通常为扩展名.exe和.dll的文件称为程序集,.exe是静态的程序集,可以在.net下直接运行加载,因为exe中有一个main函数(入口函数),.dll是动态链接库&#…

安装配置 zookeeper(单机版)

目录 一 准备并解压安装包 二 修改zoo.cfg文件 三 创建相应两个目录 四 创建文件myid 五 修改环境变量 六 启动 zookeeper 一 准备并解压安装包 这里提供了网盘资源 http://链接: https://pan.baidu.com/s/1BybwSQ_tQUL23OI6AWxwFw?pwdd4cf 提取码: d4cf 这里的安装包是…

市面上的ipad国产触控笔怎么样?开学性价比高的电容笔测评

由于Apple Pencil的问世,成为了iPad的一款便携式的生产力配件,它的优点是,与iPad相结合的电容笔,可以让专业的画师在iPad上画画,并且可以画出不同粗细的线条,这对需要书写的学生来说,是非常有用…