规范数据库设计与MySQL备份

为什么备份:

  • 保证重要的数据不丢失
  • 数据转移

 

MySQL数据库备份的方式:

  1. 直接拷贝物理文件
  2. 在可视化工具中手动导出
  3. 使用命令行导出  mysqldump  命令行使用

 

命令行导出sql文件语法:mysqldump  -h主机  -u用户名  -p密码  数据库  表名1  表名2  >  物理磁盘位置/文件名

 

为什么需要设计数据库:

当数据库比较复杂的时候,我们需要进行设计

 

糟糕的数据库设计:

  • 数据冗余,浪费空间
  • 数据库插入和删除都会很麻烦、异常【屏蔽使用物理外键】
  • 程序的性能差

良好的数据库设计:

  • 节省内存空间
  • 保证数据库的完整性
  • 方便我们开发系统

 

软件开发中,关于数据库的设计:

  • 分析需求:分析业务和需要处理的数据库的需求
  • 概要设计:设计关系图和流程图

设计数据库的步骤:

  1. 收集信息,分析需求
  2. 标识实体(把需求落实到每个字段)
  3. 标识实体之间的关系(把表和表关联起来)

 

数据库三大范式:

  • 第一范式:要求数据库没一列都是不可再分的数据项
  • 第二范式:在满足第一范式的前提下,每张表只描述一件事情
  • 第三范式:需要确保数据表没一列都和主键直接相关而不是间接相关

 

规范性和性能问题:

  1. 关联查询的表尽量不要超过三张表
  2. 考虑商业化的需求和目标,(成本,用户体验)数据库的性能更加重要
  3. 在规范性能问题的时候,需要适当的考虑一下规范性
  4. 故意给某些表增加一些冗余的字段(从多表查询变单表查询)
  5. 故意增加一些计算列(从大数据量降低为小数据量的查询)

 

posted @   吃饭睡觉娶岳梅  阅读(10)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示