数据库设计步骤

一、数据库设计重点:有效存储、高效访问

1、为什么要进行数据库设计:
(1)减少数据冗余;
(2)避免数据异常维护;
(3)节约存储空间;
(4)高效访问;
 

二、数据库设计步骤

1、需求分析;
2、逻辑设计:ER图等建模;
3、物理设计:根据每种数据库特点设计;
4、维护优化;
 

三、为什么要进行需求分析

1、了解系统中所要存储的数据;
2、了解数据的存储特点;
3、了解数据的生命周期;
比如:用户包含的属性、可唯一标识属性(用户名、电话等)、存储特点(永久保存);
存储特点:永久保存、归档存储等;
 

四、数据库范式:

1、第一范式:数据库中的所有字段都是单一属性,不可再分的;
2、第二范式:数据库的表中,不存在非关键字段对任一候选字段部分函数依赖;
3、第三范式:在第二范式基础上,字段不存在传递依赖;
4、BC范式:在第三范式基础上,复合关键字之间不存在函数依赖;
PS:部分函数依赖:某个字段,由组合关键字中的一个字段决定,比如:用户信息跟物品信息放同一张表,用户信息有用户决定,物品信息由物品决定;
 

五、物理设计:

要做什么:
1、选择合适的数据库;
2、定义数据库、表及字段的命名规范;
3、选择DBMS的字段类型(关系到使用是否高效);
4、反范式设计;
搜索引擎:myisam等;
 

六、表及字段名规范:

表名:
1、可读性原则:统一格式,比如小写下划线;
2、表意性原则:意思明确;
3、长名原则:尽可能少使用缩写;

字段类型:
影响点:
1、存储空间的开销;
2、数据查询性能;

设计原则:
1、优先选择数字类型;
2、其次是日期或二进制;
3、最后是字符型;

考虑点:
1、对数据进行比较(查询条件、join条件及排序),同样的数据,字符处理往往比数字慢;
2、在数据库中,数据处理以页为单位,列长度越小,利于性能提升;
 

七、如何选择主键:

1、区分业务主键和数据库主键:如果没有主键(Innodb会创建六个字节的隐含主键);
2、根据数据库类型,考虑主键是否要按顺序增长:有些数据库是按主键的顺序逻辑存储的;
3、主键的字段类型所占空间要尽可能的小:聚簇索引会有索引信息;

避免使用外键约束:
1、降低数据导入的效率;
2、增加维护成本;
3、虽然不使用外键,但相关联字段要加上索引;

避免使用触发器:
1、降低数据导入的效率;
2、可能会出现意想不到的异常;
3、使业务逻辑变得复杂;

禁止使用预留字段;
 

八、反范式化;以空间换时间;

为什么要反范式化:
1、减少表的关联数量;
2、增加数据的读取效率;
3、反范式化一定要适度;
 

九、维护和优化:

1、维护数据字典;
2、维护索引;
3、维护表结构;
4、在适当的时候对表进行水平拆分和垂直拆分;

索引维护:

1、如何选择合适的索引:
(1)出现在where、Group by 、Order by的字段;
(2)选择性高的列放索引前面(非必须,数据库编译的时候,会自动选择索引);
(3)索引中不要包含太长的数据类型;

2、维护索引:
(1)过多索引不仅会影响写,还影响读;
(2)定期维护索引碎片;
(3)在sql语句中,不要使用强制索引关键字(oracle);

数据库中适合的操作:
1、批量操作优于逐条操作;
2、禁止使用Select * 这样的查询;
3、控制使用用户自定义函数;
4、不要使用数据库中的全文索引;

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

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

相关文章

【CMU15-445 Part-12】Query Execution I

Part12-Query Execution I Processing Models Processing Model主要指的是明确如何去执行一个查询计划(top 2 bottom or bottom 2 top,operator之间的传递)。 Iterator Model (volcano model/pipeline model);每个算子实现一个Next( ),父…

vim缓存-交换文件

Catf1agCTF靶场 web swp 题目链接:http://catf1ag.cn/ 个人博客:https://sword-blogs.com/ 题目考点: vim在编辑文档的过程中如果异常退出,会产生缓存文件 vim 交换文件名 参考文章:vim手册 https://yianwillis.…

React 全栈体系(十六)

第八章 React 扩展 五、Context 1. 代码 /* index.jsx */ import React, { Component } from react import ./index.css//创建Context对象 const MyContext React.createContext() const {Provider,Consumer} MyContext export default class A extends Component {state …

Docker最基本使用

1 安装: sudo apt-get -y install docker.io测试: sudo docker run hello-world成功: Hello from Docker! This message shows that your installation appears to be working correctly.2 查看 查看已有镜像: sudo docker i…

Linux进程概念

文章目录 前言一、操作系统1、概念2、设计OS的目的3、总结 二、进程1、基本概念2、查看进程2.1 使用ps axj命令2.2 通过 /proc 系统文件夹查看 3、通过系统调用获取进程标示符3.1 getpid() 系统调用3.2 getppid() 系统调用 4、通过系统调用fork创建子进程4.1 使用fork创建子进程…

Linux 常用基本命令

1.走近Linux系统 开机登录 开机会启动许多程序。它们在Windows叫做"服务"(service),在Linux就叫做"守护进程"(daemon)。 关机 在linux领域内大多用在服务器上,很少遇到关机的操作。毕竟…

synchronized 和 ReentrantLock之间的区别

ReentrantLock为可重入互斥锁. 和 synchronized 定位类似 , 都是用来实现互斥效果 , 保证线程安全 . ReentrantLock的区别: 1)ReentrantLock的加锁和解锁是分开的,使用起来要手动释放锁,而sync不需要: Reentran…

【yolox训练过程中遇到的问题集合】

这里写目录标题 深度学习遇到的一系列bugVScode无法激活conda1.vscode加载web 视图报错2.CUDA out of memory3.voc2007数据集中的txt文件4.object has no attribute ‘cache‘5.KeyError:model6.No module named loguru7.Python AttributeError: module ‘distutils‘ has no a…

微信小程序 工具使用(HBuilderX)

微信小程序 工具使用:HBuilderX 一 HBuilderX 的下载二 工具的配置2.1 工具 --> 设置 --> 运行配置2.1.1 微信开发者工具路径2.1.2 node 运行配置 2.2 插件 工具 --> 插件安装2.2.1 下载插件 三 微信小程序端四 同步运行五 BUG5.1 nodemon在终端无法识别 一 HBuilderX…

没有一技之长,该如何找工作?

很负责任的告诉你,跟你一样有这个困惑的人真的太多了! 而且你也会发现,你身边的大多数人也都很迷茫。 家庭、学历一般,没啥特长爱好,更没有拿的出手的技能。 想要告诉你的是,你觉得你自己一无所长&#…

java中常见的函数式接口及简单示例

在Java中,有一些常见的函数式接口可以用于支持函数式编程和Lambda表达式的使用。以下是一些常见的函数式接口: Predicate:用于判断输入的值是否满足某个条件。它包含方法test,接收一个参数并返回一个布尔值。Function&#xff1a…

Java 8 CompletableFuture 学习及实践笔记

CompletableFuture 学习及实践笔记 CompletableFuture 是 Java 8 引入的一个强大的异步编程工具&#xff0c;它提供了一种简洁而灵活的方式来处理异步操作和构建复杂的异步流程。 创建 CompletableFuture 使用 CompletableFuture.supplyAsync(Supplier<U> supplier) 方…

pve关闭windows虚拟机慢

背景&#xff1a; 在web界面关闭windows虚拟机一直转圈&#xff0c;使用命令行关闭报错 qm stop 155 trying to acquire lock... cant lock file /var/lock/qemu-server/lock-155.conf - got timeout解决 删除lock&#xff0c;然后用命令行重新关闭 rm /var/lock/qemu-serve…

全网最全Python系列教程(非常详细)---字符串讲解(学Python入门必收藏)

&#x1f9e1;&#x1f9e1;&#x1f9e1;这篇是关于Python中字符串的讲解&#xff0c;涉及到以下内容&#xff0c;欢迎点赞和收藏&#xff0c;你点赞和收藏是我更新的动力&#x1f9e1;&#x1f9e1;&#x1f9e1; 本文将从以下几个方面展开对字符串的讲解&#xff1a; 1、字…

如何使用docker快速部署MinDoc文档系统

MinDoc是非常优秀的知识分享系统&#xff0c;但是很多刚接触的人会一脸懵逼&#xff0c;而且官方文档写的也并不清晰&#xff0c;所以和大家分享一下快速部署MinDoc的方法。 首先docker环境先自行安装好&#xff0c;这里不再赘述。 拉取docker镜像&#xff1a; docker pull …

利用 Forcing InnoDB Recovery 特性解决 MySQL 重启失败的问题

问题 由于异常断电或者系统异常重启时 MySQL 没有正常退出导致 MySQL 无法启动&#xff0c;启动时报错如下&#xff1a; [System] [Server] /usr/sbin/mysqld (mysqld 8.0.30) starting as process 2665 [System] [InnoDB] InnoDB initialization has started. [System] [Inn…

golang 对不同结构体中数据进行相互转换的几种常用方法

常用的不同结构体中的数据相互转换的方法 1. 利用json包的marshal和unmarshal 要求&#xff1a;json标签的值必须一致 示例: package main import ("encoding/json""fmt" ) type A struct {Name string json:"name"Age int json:"age&qu…

【开发篇】九、SpringBoot整合ES(ElasticSearch)

文章目录 1、整合2、简单示例3、一点补充4、增删改查索引与文档 1、整合 整合思路都一样&#xff0c;先起步依赖或普通依赖&#xff0c;再配置&#xff0c;再封装的操作对象。先引入依赖&#xff1a; <dependency> <groupId>org.springframework.boot</grou…

基于Java的电影评论网站设计与实现

项目描述 临近学期结束&#xff0c;还是毕业设计&#xff0c;你还在做java程序网络编程&#xff0c;期末作业&#xff0c;老师的作业要求觉得大了吗?不知道毕业设计该怎么办?网页功能的数量是否太多?没有合适的类型或系统?等等。今天给大家介绍一篇基于Java的电影评论网站…

内存泄漏,内存溢出,抽象类和接口,netstat、ping、ifconfig的区别

持续学习是我们必备的技能之一&#xff0c;保持与时俱进&#xff0c;保持行业的敏感度&#xff0c;关注行业发展趋势&#xff0c;了解新技术&#xff0c;加强自己的认知&#xff0c;积极的应对变化 内存泄漏 memory leak 是指程序在申请内存后&#xff0c;无法释放已申请的内…