Shema与数据类型优化

本文介绍了MySQL中整数类型的选择,包括有符号和无符号的区别,以及宽度对存储和计算的影响。同时,讨论了缓存表与汇总表在优化中的作用,并分享了加快ALTER TABLE操作速度的技巧,包括避免全表复制的方法。最后,提出了简单数据库设计的基本原则,如选用合适的数据类型,避免NULL值,以及避免使用已废弃的特性。
摘要由CSDN通过智能技术生成

1、优化的数据类型(只列举了常用的数据类型)
1.1整数类型
整数类型有:TINYINT, SMALLINT, MEDIUMINT, INT, BIGINT 。分别使用8,16,24,32,64位存储空间,存储的值的范围是从-2^(N-1) 到 2^(N-1)-1,其中N 是存储空间的位数。
整数类型有可选的UNSIGNED属性,表示不允许负值,可以让正数的上限提高一倍。例如 TINYINT,UNSIGNED可以存储的范围是0-255,而TINYINT的存储范围是-128~127。
有符号和无符号类型使用相同的存储空间,并具有相同的性能,因此可以根基实际情况选择合适的类型。
MySQL可以为整数类型指定宽度,例如INT(11),但实际上对大多数应用是没有意义的:它不会限制值的合法范围,只是规定了MySQL的一些交互工具(例如MySQL命令行客户端)用来显示字符的个数。对于存储和计算来说,INT(1)和INT(20)是相同的。

  1.2 字符串类型
  VARCHAR
  VARCHAR用于存储可变长字符串,是最常见的字符串数据类型,它比定长类型更节省空间,因为它仅使用必要的空间(越短的字符串使用越少的空间)。有一种情况例外,如果MySQL表使用ROW_FORMAT=FIXED创建的话,每一行都会使用定长存储,这会很浪费空间。
  VARCHAR需要使用1或2个额外字节记录字符串的长度:如果列的最大长度小于或等于255字节,则只使用1个字节表示,否则使用2个字节。
  虽然VARCHAR节省了存储空间,对性能有帮助。但是,由于行是变长的,在UPDATE时可能使行变的比
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值