MySQL性能优化之数据类型

MySQL支持非常多的数据类型,选择正确的类型对于获得高性能至关重要。

以下几个原则有助于做出更好的选择:
(1)更小的通常更好:尽量使用可以正确存储数据的最小的数据类型,更小的数据类型通常更快,因为它们占用更少的磁盘,CPU和内存,并且处理时需要的CPU周期也更加少。但是这里需要注意选择的最小类型要包含业务的最大范围。
(2)简单就好:简单数据类型的操作通常需要更少的CPU周期。例如:整型比字符型的代价更低,因为字符集和校验规则使得字符型更加复杂。在选择数据类型的时候应该尽量选择MySQL内建类型,如不适用字符串来存储日期和时间,使用整型存储IP等。
(3)尽量避免NULL:如果在查询中包含可为NULL的列,这对于MySQL将更加难以优化,因为可为NULL的列使得索引、索引统计和值都更加复杂。可为NULL的列需要更多的存储空间,MySQL也要对其特殊处理(当可为NULL的列被索引的时候,每一个索引记录都需要一个额外的字节),通常把NULL改为NOT NULL带来的性能提升比较小,所以在调优的时候没有必要马上改掉这种情况。

例如:DATATIME和TIMESTAMP都可以存储相同类型的数据:时间和日期,精确到秒。但是TIMESTAMP只是用DATETIME一半的存储空间,并且会根据时区变化。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值