我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MYSQL数据库表结构优化方法详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MYSQL数据库表结构优化方法详解

本文实例讲述了MYSQL数据库表结构优化方法。分享给大家供大家参考,具体如下:

 选择合适的数据类型

    1、使用可以存下你的数据的最小的数据类型

    2、使用简单的数据类型。Int要比varchar类型在mysql处理上简单

    3、尽可能的使用not null定义字段

    4、尽量少用text类型,非用不可时最好考虑分表

使用int来存储日期时间,利用FROM_UNIXTIME()【将int类型时间戳转换成日期时间格式】,UNIX_TIMESTAMP()【将日期时间格式转换成int类型】两个函数进行转换

使用bigint来存储IP地址,利用INET_ATON()【将IP格式转换成int】,INET_NTOA()【将int格式转换成正常IP格式】两个函数进行转换

表的范式化和反范式化

范式化是指数据库设计的规范,目前的范式化一般指第三设计范式,也就是要求数据表中不存在非关键字段对任意候选关键字段

的传递函数依赖则符合第三范式。

MYSQL数据库表结构优化方法详解

不符合第三范式要求的表存在下列问题:

    1、数据冗余:(分类,分类描述)对于每一个商品都会进行记录

    2、数据的插入/更新/删除异常

范式化操作:

MYSQL数据库表结构优化方法详解

反范式化是指为了查询效率和考虑把原本符合第三范式的表适当的增加冗余,以达到优化查询效率的目的,反范式化是一种以空间来换取时间的操作。

例:

MYSQL数据库表结构优化方法详解

MYSQL数据库表结构优化方法详解   

对表进行反范式化

MYSQL数据库表结构优化方法详解

反范式化查询订单信息:

MYSQL数据库表结构优化方法详解

表的垂直拆分

   垂直拆分就是把原来 很多列的表拆分成多个表,这就解决了表的宽度问题。通常垂直拆分可以按以下原则进行:

        1、把不常用的字段单独存放到一个表中。

        2、把大字段独立存放到一个表中。

        3、把经常一起使用的字段放到一起。

水平拆分

    表的水平拆分是为了解决单表的数据量过大问题,水平拆分的表每个表的结构都是完全一致的

MYSQL数据库表结构优化方法详解

 常用的水平拆分方法:

    1、对customer_id进行hash运算,如果要拆分成5个表则使用mod(custoneer_id,5)取出0-4个值

    2、针对不同的hashID把数据存到不同的表中

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL查询技巧大全》、《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》及《MySQL数据库锁相关技巧汇总》

希望本文所述对大家MySQL数据库计有所帮助。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MYSQL数据库表结构优化方法详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

数据库-表结构设计性能优化

在进行数据库表结构设计时,最优性能设计建议如下:1、客户端IP两种存储方式(不考虑ipv6):? ? 1)、int? ? 2)、 char(10)? ? 性能上考虑推荐使用int。2、有些表的电话号码 改成varchar(12),严格上使用char(11),有
数据库-表结构设计性能优化
2018-02-21

详解 linux mysqldump 导出数据库、数据、表结构

详解 linux mysqldump 导出数据库、数据、表结构 导出完整的数据库备份:mysqldump -h127.0.0.1 -P3306 -uroot -ppassword --add-locks -q dbname > dbname
2022-06-04

MySQL表结构优化管理的方法是什么

MySQL表结构优化管理的方法包括以下几个方面:正确选择数据类型:选择适当的数据类型可以减小存储空间的占用,并提高查询和索引的效率。例如,使用INT代替VARCHAR存储数字数据。创建合适的索引:根据查询的需求和表的特点,创建适当的索引可以
2023-10-24

SQL笔记之数据库结构优化方式

数据库结构优化是指通过调整数据库结构以提高查询效率的措施。优化方案包括:选择合适的数据类型规范化数据库创建索引分区表使用视图和物化视图表分区及数据类型转换正确创建和使用索引类型定期更新数据库统计信息
SQL笔记之数据库结构优化方式
2024-04-02

ZABBIX数据库表结构解析

ZABBIX数据库表结构解析      下面开始介绍: 1.添加监控表结构详解 (1)hosts,存储被监控的机器的信息,表结构如下:   (2)i
ZABBIX数据库表结构解析
2020-01-14

MySQL总结(七)数据库表的约束-详解

数据库表的约束1. 数据库约束的概述1.1 约束的作用:对表中的数据进行限制,保证数据的正确性、有效性和完整性。一个表如果添加了约束,不正确的数据将无法插入到表中。约束在创建表的时候添加比较合适。1.2 约束种类:约束名约束关键字特点主键primary key
MySQL总结(七)数据库表的约束-详解
2017-04-03

编程热搜

目录