当前位置: 首页 > article >正文

别再死记硬背了!用‘借书还书’的例子,5分钟搞懂数据库1NF到BCNF

图书馆借阅系统里的数据库范式从1NF到BCNF的实战推演想象你走进一家老式图书馆木质书架散发着油墨香气管理员正用纸质登记簿记录借阅信息。某天馆长决定数字化管理请你设计数据库。当你翻开《数据库系统概论》却被范式概念绕晕——别急让我们用借书还书的故事拆解这些抽象规则背后的实际意义。1. 初始混乱零范式的借阅登记簿老馆长的登记簿长这样读者卡号读者信息图书信息借阅日期归还日期1001张三, 历史系, 教授《史记》BK001,《资治通鉴》BK0022023-05-102023-06-101002李四, 数学系, 学生《线性代数》BK0032023-05-122023-06-12问题肉眼可见读者信息混杂姓名、院系、职称图书信息打包了多本书的编号和书名同一读者重复借书时院系信息会被反复记录提示这就像把不同颜色的乐高积木强行粘在一起既无法拆分重组也造成存储空间浪费。2. 第一范式1NF拆解信息原子我们首先确保每个字段不可再分CREATE TABLE 借阅记录 ( 读者卡号 INT, 姓名 VARCHAR(50), 院系 VARCHAR(50), 职称 VARCHAR(20), 图书编号 VARCHAR(10), 图书书名 VARCHAR(100), 借阅日期 DATE, 归还日期 DATE );关键改进将复合字段拆分为独立列每本书单独记录BK001和BK002变成两条记录新痛点张三借100本书他的院系信息会被重复存储100次若历史系改名文史学院需要更新所有相关记录3. 第二范式2NF消除部分依赖分析字段间的依赖关系读者卡号 → 姓名、院系、职称图书编号 → 图书书名(读者卡号 图书编号 借阅日期) → 归还日期解决方案是拆表-- 读者信息表 CREATE TABLE 读者 ( 读者卡号 INT PRIMARY KEY, 姓名 VARCHAR(50), 院系编号 VARCHAR(10), 职称 VARCHAR(20) ); -- 院系表 CREATE TABLE 院系 ( 院系编号 VARCHAR(10) PRIMARY KEY, 院系名称 VARCHAR(50) ); -- 图书表 CREATE TABLE 图书 ( 图书编号 VARCHAR(10) PRIMARY KEY, 书名 VARCHAR(100) ); -- 借阅记录表 CREATE TABLE 借阅记录 ( 记录ID INT PRIMARY KEY, 读者卡号 INT, 图书编号 VARCHAR(10), 借阅日期 DATE, 归还日期 DATE, FOREIGN KEY (读者卡号) REFERENCES 读者(读者卡号), FOREIGN KEY (图书编号) REFERENCES 图书(图书编号) );优化效果院系名称只存储一次通过院系编号关联图书信息独立维护修改书名只需更新一处借阅记录表体积大幅减小4. 第三范式3NF切断传递依赖检查发现读者表包含院系编号→院系名称的传递依赖。继续拆分-- 读者表优化后 CREATE TABLE 读者 ( 读者卡号 INT PRIMARY KEY, 姓名 VARCHAR(50), 院系编号 VARCHAR(10), 职称 VARCHAR(20), FOREIGN KEY (院系编号) REFERENCES 院系(院系编号) );连锁反应新增院系时无需等待该院系有读者删除读者不会连带删除院系信息院系改名只需修改院系表中的一条记录5. BCNF主键间的终极较量假设新增业务规则每位教授只能负责指导特定院系的学生。我们设计指导关系表教授卡号学生卡号院系编号10012001HIST10012002HIST10032003MATH依赖分析(教授卡号 学生卡号) → 院系编号教授卡号 → 院系编号教授只能指导本系学生这导致主键(教授卡号,学生卡号)中的部分决定关系。BCNF要求我们拆分为CREATE TABLE 教授院系 ( 教授卡号 INT PRIMARY KEY, 院系编号 VARCHAR(10), FOREIGN KEY (教授卡号) REFERENCES 读者(读者卡号), FOREIGN KEY (院系编号) REFERENCES 院系(院系编号) ); CREATE TABLE 学生指导 ( 学生卡号 INT PRIMARY KEY, 教授卡号 INT, FOREIGN KEY (学生卡号) REFERENCES 读者(读者卡号), FOREIGN KEY (教授卡号) REFERENCES 教授院系(教授卡号) );6. 范式应用的实战权衡在真实项目中有时需要反范式化设计。比如高频查询显示读者姓名书名借阅日期完全范式化需要多表连接SELECT r.姓名, b.书名, l.借阅日期 FROM 借阅记录 l JOIN 读者 r ON l.读者卡号 r.读者卡号 JOIN 图书 b ON l.图书编号 b.图书编号;性能优化策略在借阅记录表中冗余存储读者姓名和书名违反3NF但提升查询速度使用物化视图预计算常用查询按业务场景选择隔离级别如借书操作需要SERIALIZABLE级别最后记住范式是工具而非教条。我曾见过一个图书管理系统在3NF设计下查询缓慢通过适当增加冗余字段使响应时间从2秒降至200毫秒。好的数据库设计永远在规范约束与性能需求之间寻找平衡点。

相关文章:

别再死记硬背了!用‘借书还书’的例子,5分钟搞懂数据库1NF到BCNF

图书馆借阅系统里的数据库范式:从1NF到BCNF的实战推演 想象你走进一家老式图书馆,木质书架散发着油墨香气,管理员正用纸质登记簿记录借阅信息。某天,馆长决定数字化管理,请你设计数据库。当你翻开《数据库系统概论》&a…...

小红书内容管理神器:XHS-Downloader让内容采集变得如此简单

小红书内容管理神器:XHS-Downloader让内容采集变得如此简单 【免费下载链接】XHS-Downloader 小红书(XiaoHongShu、RedNote)链接提取/作品采集工具:提取账号发布、收藏、点赞、专辑作品链接;提取搜索结果作品、用户链接…...

从手机热点到云平台:ESP8266 Wi-Fi模块的完整入网调试指南(含STA模式配置避坑点)

从手机热点到云平台:ESP8266 Wi-Fi模块的完整入网调试指南 在物联网设备开发中,稳定可靠的网络连接是项目成功的关键前提。ESP8266作为一款高性价比的Wi-Fi模块,其灵活的工作模式和丰富的AT指令集使其成为众多开发者的首选。然而&#xff0c…...

从《亦爱亦恨话纽约》看城市数据可视化:用Python+Folium绘制纽约的‘能量’与‘摩擦’地图

数据视角下的都市脉搏:用Python绘制纽约的活力与冲突地图 纽约的街道永远在讲述着两种截然不同的故事——玻璃幕墙反射的金融区阳光与地铁通道里斑驳的涂鸦,米其林餐厅的银质餐具与街头餐车的纸咖啡杯,中央公园晨跑者的心率监测与布朗克斯区急…...

BitTorrent Tracker服务器在亚洲节点的部署优化实践

BitTorrent Tracker服务器在亚洲节点的部署优化实践 【免费下载链接】trackerslist Updated list of public BitTorrent trackers 项目地址: https://gitcode.com/GitHub_Trending/tr/trackerslist ngosang/trackerslist作为开源技术社区中维护的公共BitTorrent Tracker…...

从踩坑到避坑:我的INA226模块调试血泪史(附常见问题排查与校准指南)

从踩坑到避坑:我的INA226模块调试血泪史(附常见问题排查与校准指南) 第一次接触INA226时,我以为这不过是个普通的电流检测模块——接上电源、连好I2C、读取寄存器数据就完事了。直到项目deadline前三天,发现测量数据飘…...

WebLaTeX:免费在线LaTeX编辑器的终极指南,告别复杂配置的学术写作新体验

WebLaTeX:免费在线LaTeX编辑器的终极指南,告别复杂配置的学术写作新体验 【免费下载链接】WebLaTex A complete alternative for Overleaf with VSCode Web Git Integration Copilot Grammar & Spell Checker Live Collaboration Support. Base…...

告别标定噩梦:手把手教你用OpenCV搞定Jetson Nano双目摄像头标定,并适配ORB_SLAM2

双目视觉标定实战:从Jetson Nano到ORB_SLAM2的完整指南 在计算机视觉领域,双目摄像头的标定是构建三维感知系统的关键第一步。许多开发者在使用Jetson Nano搭配双目摄像头运行ORB_SLAM2时,往往会在标定环节耗费大量时间却收效甚微。本文将彻底…...

3分钟快速汉化Android Studio:中文语言包完整配置指南

3分钟快速汉化Android Studio:中文语言包完整配置指南 【免费下载链接】AndroidStudioChineseLanguagePack AndroidStudio中文插件(官方修改版本) 项目地址: https://gitcode.com/gh_mirrors/an/AndroidStudioChineseLanguagePack 还在为Android …...

Stata实战:用twoway函数一步步画出漂亮的Logistic回归交互效应图(附不孕症数据)

Stata数据可视化进阶:打造学术级Logistic回归交互效应图 第一次在学术会议上看到那些色彩协调、信息密度极高的统计图表时,我意识到数据可视化远不止是把数字变成图形那么简单。作为经常处理医学研究数据的分析师,我发现很多同行在Stata中能跑…...

别再傻傻用软件AES了!STM32硬件AES实战:从CubeMX配置到DMA传输的完整流程

STM32硬件AES实战指南:从配置到DMA优化的全流程解析 在嵌入式系统开发中,数据安全已经成为不可忽视的核心需求。想象一下,你正在开发一款智能门锁产品,需要通过网络传输开锁指令,或者设计一款医疗设备,需要…...

抖音下载器完整指南:3分钟掌握批量下载无水印视频的终极方法

抖音下载器完整指南:3分钟掌握批量下载无水印视频的终极方法 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback…...

相控阵天线设计避坑指南:阵元间距、扫描角与栅瓣的那些事儿

相控阵天线设计实战:从阵元间距到波束扫描的工程陷阱解析 相控阵天线技术正在重塑现代雷达和通信系统的设计范式。不同于传统机械扫描天线,相控阵通过电子控制实现波束的快速转向与重构,这种灵活性使其在5G基站、卫星通信和军用雷达等领域展现…...

OBS Composite Blur插件:直播模糊特效的终极解决方案

OBS Composite Blur插件:直播模糊特效的终极解决方案 【免费下载链接】obs-composite-blur A comprehensive blur plugin for OBS that provides several different blur algorithms, and proper compositing. 项目地址: https://gitcode.com/gh_mirrors/ob/obs-c…...

STM32H743 FDCAN接收中断实战:从CubeMX配置到串口打印数据的完整流程

STM32H743 FDCAN接收中断实战:从CubeMX配置到串口打印数据的完整流程 在嵌入式开发中,CAN总线通信因其高可靠性和实时性被广泛应用于汽车电子、工业控制等领域。STM32H743作为STMicroelectronics推出的高性能微控制器系列,其内置的FDCAN&…...

3个实战技巧深度解析百度网盘链接:Python工具实现高速下载的完整指南

3个实战技巧深度解析百度网盘链接:Python工具实现高速下载的完整指南 【免费下载链接】baidu-wangpan-parse 获取百度网盘分享文件的下载地址 项目地址: https://gitcode.com/gh_mirrors/ba/baidu-wangpan-parse 百度网盘解析工具是一款基于Python开发的开源…...

解锁学术新秘籍:书匠策AI——期刊论文的智能导航员

在学术的浩瀚海洋中,每一位探索者都渴望拥有一盏明灯,照亮前行的道路,尤其是在撰写期刊论文这一艰巨任务面前。传统上,这往往意味着无数次的文献检索、框架搭建、内容填充与反复修改,过程既耗时又费力。但如今&#xf…...

解锁学术新秘籍:书匠策AI——你的期刊论文智囊团

在学术探索的浩瀚海洋中,每一位学者都渴望拥有一盏明灯,照亮前行的道路,尤其是在撰写期刊论文这一复杂而精细的任务面前。今天,就让我们一起揭开一个神秘而强大的工具——书匠策AI的神秘面纱,探索它如何成为你期刊论文…...

告别数据线?实测用手机Termux+网络串口给ESP32无线OTA升级

手机Termux网络串口实现ESP32无线OTA升级全攻略 想象一下这样的场景:你正坐在咖啡馆里,突然灵感迸发想修改ESP32设备的固件。传统方式需要翻出数据线、连接电脑、打开开发环境...但现在,只需掏出手机就能完成从代码修改到固件烧录的全流程。这…...

图论基础:图的表示、遍历、最短路径入门

文章目录前言一、图论入门:先搞懂什么是图1.1 图的核心定义1.2 图的常见分类(1)无向图 vs 有向图(2)无权图 vs 有权图1.3 图的基础术语二、图的表示:计算机怎么存储图2.1 邻接矩阵:直观但费空间…...

Windows 11 LTSC微软商店终极安装指南:3步恢复完整应用生态

Windows 11 LTSC微软商店终极安装指南:3步恢复完整应用生态 【免费下载链接】LTSC-Add-MicrosoftStore Add Windows Store to Windows 11 24H2 LTSC 项目地址: https://gitcode.com/gh_mirrors/ltscad/LTSC-Add-MicrosoftStore Windows 11 LTSC系统以其卓越的…...

别再用词频统计了!用LDA主题模型挖掘荣耀50评论里的真实用户需求(附Python代码)

超越词频统计:用LDA主题模型解码荣耀50用户评论的深层需求 每次打开电商平台的评论区,那些密密麻麻的文字背后到底藏着什么秘密?作为数据分析师,我们常常陷入这样的困境:明明收集了海量用户反馈,却只能做出…...

WorkshopDL:打破平台壁垒的模组自由之门

WorkshopDL:打破平台壁垒的模组自由之门 【免费下载链接】WorkshopDL WorkshopDL - The Best Steam Workshop Downloader 项目地址: https://gitcode.com/gh_mirrors/wo/WorkshopDL 想象一下,您在Epic Games Store上购买了一款心仪已久的游戏&…...

终极指南:3步让旧Mac焕发新生,OpenCore Legacy Patcher完整使用教程

终极指南:3步让旧Mac焕发新生,OpenCore Legacy Patcher完整使用教程 【免费下载链接】OpenCore-Legacy-Patcher Experience macOS just like before 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 还在为旧款Mac无法…...

5个步骤快速掌握Fiji:生命科学图像分析的终极工具指南

5个步骤快速掌握Fiji:生命科学图像分析的终极工具指南 【免费下载链接】fiji A "batteries-included" distribution of ImageJ :battery: 项目地址: https://gitcode.com/gh_mirrors/fi/fiji 如果你正在寻找一款能轻松处理显微镜图像、分析细胞结构…...

PvZ Toolkit:植物大战僵尸终极免费修改器完整指南

PvZ Toolkit:植物大战僵尸终极免费修改器完整指南 【免费下载链接】pvztoolkit 植物大战僵尸 PC 版综合修改器 项目地址: https://gitcode.com/gh_mirrors/pv/pvztoolkit 还在为植物大战僵尸无尽模式中阳光不足而烦恼吗?是否曾经精心布置的完美阵…...

终极抖音封面提取指南:3步掌握高清素材批量获取

终极抖音封面提取指南:3步掌握高清素材批量获取 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback support. 抖…...

QMCDecode终极指南:3分钟解锁QQ音乐加密文件,释放你的音乐自由

QMCDecode终极指南:3分钟解锁QQ音乐加密文件,释放你的音乐自由 【免费下载链接】QMCDecode QQ音乐QMC格式转换为普通格式(qmcflac转flac,qmc0,qmc3转mp3, mflac,mflac0等转flac),仅支持macOS,可自动识别到QQ音乐下载目…...

3分钟掌握MusicFree插件:解锁全网免费音乐终极指南

3分钟掌握MusicFree插件:解锁全网免费音乐终极指南 【免费下载链接】MusicFreePlugins MusicFree播放插件 项目地址: https://gitcode.com/gh_mirrors/mu/MusicFreePlugins 还在为音乐平台的VIP限制而烦恼吗?想要在一个应用中畅享B站、YouTube、猫…...

3步精通Zotero Better Notes:打造终极学术笔记管理系统

3步精通Zotero Better Notes:打造终极学术笔记管理系统 【免费下载链接】zotero-better-notes Everything about note management. All in Zotero. 项目地址: https://gitcode.com/gh_mirrors/zo/zotero-better-notes Zotero Better Notes是一款革命性的Zote…...