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

MySQL数据库调优————表结构设计优化

三范式

第一范式

  • 字段具有原子性,即数据库表的每一个字段都是不可分割的原子数据项,不能是集合、数组、记录等非原子数据项
  • 当实体中的每个属性有多个值时,必须拆分为不同的属性

第二范式

  • 满足第一范式的基础上,要求每一行数据具有唯一性,并且非主键字段完全依赖主键字段

第三范式

  • 满足第二范式的基础上,不能存在传递依赖

反模式设计

-适当增加冗余,从而提升查询效率

表设计原则

  • 字段少而精,建议20个以内(经验之谈),超过可以拆分
    • 把常用字段放在一起
    • 把不常用的字段独立除去
    • 大字段(TEXT/BLOB/CLOB等等)独立出去
  • 尽量使用小型字段
    • 使用数字替代字符串
  • 避免使用允许为NULL的字段
    • 允许为NULL的字段很难进行查询优化
    • 允许为NULL的索引需要额外的空间
  • 合理平衡范式与冗余
  • 在数据量大的情况下,可以考虑分库分表
http://www.lryc.cn/news/12936.html

相关文章:

  • set对象和map对象
  • stream()流的使用
  • C++学习笔记-常量
  • JavaScript系列之实现继承的几种方式
  • java面试准备
  • kafka-6-python单线程操作kafka
  • 【Spring教程】1.Spring概述
  • 设计模式-代理模式
  • DPDK — MALLOC(librte_malloc,Memory Manager,内存管理组件)
  • 【Java开发】Spring 12 :Spring IOC控制反转和依赖注入(解决单接口多实现类调用)
  • 【C++学习】基础语法(三)
  • k8s自动化安装脚本(kubeadm-1.23.7)
  • 面试题记录
  • 链式前向星介绍以及原理
  • jenkins 安装 -适用于在线安装 后续写个离线安装的
  • 【C++】再谈vscode界面调试C++程序(linux) - 知识点目录
  • 蚂蚁感冒---第五届蓝桥杯真题
  • 常见排序算法--Java实现
  • 算法笔记(九)—— 暴力递归
  • Flask框架学习记录
  • 【Opencv 系列】 第6章 人脸检测(Haar/dlib) 关键点检测
  • 信源分类及数学模型
  • Games101-202作业1
  • Linux系统之终端管理命令的基本使用
  • 【Mongoose笔记】MQTT 服务器
  • 数据结构概述
  • 【前端】Vue3+Vant4项目:旅游App-项目总结与预览(已开源)
  • 51单片机蜂鸣器的使用
  • 算法练习-链表(二)
  • LabVIEW使用实时跟踪查看器调试多核应用程序