三范式,面试重点

三范式都是拿来解决数据冗余的问题

第一范式:

表必须有主键,它确保表中的每一列都是原子性的,

第二范式

定义:数据库表必须满足第一范式,且表中的非主属性完全依赖于主键。非主属性是指除了主键之外的其他属性。完全依赖指的是非主属性只能由主键决定,而不能由主键的一部分来决定(不能部分依赖)
多对多关系?三张表,关系表

第三范式

定义:数据库表必须满足第二范式,且表中的非主属性不传递依赖于主键。传递依赖指的是某个非主属性依赖于另一个非主属性,而这个非主属性又依赖于主键。

一对多?两张表,多的表加外键

  • 在实际开发中,以满足客户的需求为主,有的时候会拿冗余换执行速度(说出这个是加分),三范式只是理论
相关推荐
云草桑11 分钟前
DBA 运维 数据库 备份 还原 MSSQL
数据库·dba·mssql
月明长歌16 分钟前
【码道初阶】【LeetCode 572】另一棵树的子树:当“递归”遇上“递归”
算法·leetcode·职场和发展
给朕把屎铲了17 分钟前
涛思数据库:DB error: some vnode/qnode/mnode(s) out of service (10.703928s)
大数据·数据库·涛思数据
C雨后彩虹30 分钟前
最大数字问题
java·数据结构·算法·华为·面试
先做个垃圾出来………43 分钟前
如何判断一个SQL逻辑是否需要拆分为多个事务单元
数据库·sql·oracle
嫂子的姐夫44 分钟前
py连接MongoDB
数据库·爬虫·mongodb
suoyue_zhan1 小时前
GBase 8s V8.8 安装部署实践指南
前端·数据库·chrome
晨曦5432101 小时前
数据库视图:数据安全与查询利器
数据库·sql·mysql
Java天梯之路1 小时前
Spring Boot 启动流程源码解析:从 `main()` 到 Web 服务就绪
java·spring boot·面试
漂亮的小碎步丶1 小时前
【3】Spring事务管理
java·数据库·spring