MySQL之表结构设计

Schema设计原则 :

  1. 更小的数据类型,根据估计选择不会超过范围的最小数据类型。
  2. 简单数据类型的操作通常需要更少的CPU周期。例如整型比字符操作代价更低,因为字符集和校对规则(排序规则)使字符比较比整型比较更复杂。

尽量避免NULL:最好指定列为NOT NULL,除非真的需要存储NULL值。NULL列使得索引、索引统计和值比较都更复杂,使用更多的存储空间。如果计划在列上建索引,就应该尽量避免设计成可为NULL的列

 

实数类型

  1. FLOAT DOUBLE类型支持使用标准的浮点运算进行近似计算。DECIMAL类型用于存储精确的小数
  2. CPU直接支持原生浮点计算,所以浮点运算明显更快。

因为需要额外的空间和计算开销,所以尽量只在对小数进行精确计算时才使用DECIMAL—例如存储财务数据。但在数据量比较大的时候,可以考虑使用BIGINT代替DECIMAL,将需要存储的数值根据小数的位数乘以相应倍数即可

 

字符串类型

下面这些情况使用VARCHAR:

  1. 字符串列的最大长度比平均长度大很多;
  2. 列的更新很少,所以碎片不是问题;
  3. 使用了像UTF-8这样复杂的字符集,每个字符都使用不同的字节数进行存储

CAHR的使用场景:

  1. CHAR类型是定长的,适合存储很短的字符串,或所有值接近同一个长度;

 枚举类型

  1. 把一些不重复的字符串存储成一个预定义的集合。MySQL在存储枚举时非常紧凑,会根据列表值的数量压缩到一个或者两个字节中。
  2. 枚举最不好的地方是,字符串列表是固定的,添加或删除字符串必须使用ALTER TABLE,因此对于未来可变的字符串,不建议使用枚举

 特殊数据类型

IPv4 地址:虽然经常使用VARCHAR(15)列来存储IP地址。然而,它们实际上是32位无符号整数,不是字符串。用小数点将地址分成四段的表示方法只是为了让人们阅读容易。所以应该用无符号整数存储IP地址。MySQL提供INET_ATON() 和 INET_NTOA()函数在这两种表示方法之间转换。varchar存储ip地址的弊端之一是:无法根据指定的ip地址范围进行区间搜索,而转换为32位无符号整数则可以

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值