设计数据库

1、什么是实体

实体就是软件开发过程中所涉及的事务,通常都是一类数据对象的个体。

2、什么是数据库设计

数据库设计就是将实体与实体之间的关系进行规划和结构化的过程。

3、为什么要对数据库进行设计

当存储的数据比较少的时候,当然不需要对数据库进行设计。但是,当对数据的需求量越来越大时,对

数据库的设计就很有必要性了!如果数据库的设计不当,会造成数据冗余、修改复杂、操作数据异常等

问题。而好的数据库设计,则可以减少不必要的数据冗余,通过合理的数据规划提高系统的性能。

4、如何设计数据库

收集信息 :在确定客户要做什么之后,收集一切相关信息,尽量不要遗漏信息
标识实体 :实体一般是名词,每个实体只描述一件事情,不能重复出现含义相同的实体
标识实体的详细属性
标识实体之间的关系

5、ER图

5.1、什么是ER图

ER=Entity Relational(实体关系)

ER图就是实体关系图

5.2、如何画ER图

6、数据库模型图

6.1、什么事关系模式

实体关系的描述称为关系模式,关系模式通常使用二维表的形式表示

eg:学生(学号,姓名,性别,年龄,所属班级)

6.2、关系模式转为数据库模型图

将关系模式使用Navicat工具转换为数据库模型图,转换步骤如下:

  1. 将各实体转换为对应的表,将各属性转换为各表对应的列
  2. 标识每个表的主键列
  3. 在表之间建立主外键,体现实体
    eg:

7、数据库三大范式

7.1、第一范式

第一范式是最基本的范式,确保每列保持原子性,也就是每列不可再分。

eg:

7.2、第二范式

第二范式是在第一范式的基础上,每张表的属性完全依赖于主键,也就是每张表只描述一件事情

eg:

7.3、第三范式

第三范式是在第二范式的基础上,确保每列都直接依赖于主键,而不是间接依赖于主键,也就是不能存

在传递依赖。比如A依赖于B,B依赖于C,这样A间接依赖于C。

注意:

在实际开发过程中,为了满足性能的需要,数据库的设计可能会打破数据库三大范式的约束
以空间换时间

当数据库中存储的数据越来越多时,查询效率下降,为了提升了查询效率,可能会在表

中增加新的字段,此时,数据库的设计就不再满足三大范式。

相关推荐
吴声子夜歌1 小时前
SQL经典实例——使用多张表
数据库·sql
倔强的石头_2 小时前
《Kingbase护城河》——深度解密数据库行锁冲突与等待事件架构
数据库
IT策士3 小时前
Redis 从入门到精通:性能调优与多语言客户端对比
数据库·redis·缓存
Bert.Cai3 小时前
Oracle INSTR函数详解
数据库·oracle
茉莉玫瑰花茶5 小时前
综合案例 - AI 智能租房助手 [ 5 ]
服务器·数据库·人工智能·python·ai
ywl4708120875 小时前
jwt生产token,简单版helloworld
java·数据库·spring
器灵科技5 小时前
AI视频工具实测:Seedance/可灵/HappyHorse谁最能打?
java·运维·数据库·人工智能·github
huangdong_6 小时前
京东商品图片视频批量下载与m3u8视频合并技术完整实现方案
大数据·前端·数据库
倒流时光三十年6 小时前
PostgreSQL CASE 条件表达式详解
数据库·postgresql
字节跳动数据平台6 小时前
营销视频进入工业化时代,火山引擎多模态数据湖如何助力多米实现内容生产提效 100+ 倍
数据库