本文实例讲述了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格式】两个函数进行转换
表的范式化和反范式化
范式化是指数据库设计的规范,目前的范式化一般指第三设计范式,也就是要求数据表中不存在非关键字段对任意候选关键字段
的传递函数依赖则符合第三范式。
不符合第三范式要求的表存在下列问题:
1、数据冗余:(分类,分类描述)对于每一个商品都会进行记录
2、数据的插入/更新/删除异常
范式化操作:
反范式化是指为了查询效率和考虑把原本符合第三范式的表适当的增加冗余,以达到优化查询效率的目的,反范式化是一种以空间来换取时间的操作。
例:
对表进行反范式化
反范式化查询订单信息:
表的垂直拆分
垂直拆分就是把原来 很多列的表拆分成多个表,这就解决了表的宽度问题。通常垂直拆分可以按以下原则进行:
1、把不常用的字段单独存放到一个表中。
2、把大字段独立存放到一个表中。
3、把经常一起使用的字段放到一起。
水平拆分
表的水平拆分是为了解决单表的数据量过大问题,水平拆分的表每个表的结构都是完全一致的
常用的水平拆分方法:
1、对customer_id进行hash运算,如果要拆分成5个表则使用mod(custoneer_id,5)
取出0-4个值
2、针对不同的hashID把数据存到不同的表中
更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL查询技巧大全》、《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》及《MySQL数据库锁相关技巧汇总》
希望本文所述对大家MySQL数据库计有所帮助。
MYSQL,数据库,表结构,优化
更新日志
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]