MySQL性能优化之数据类型

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Alpha_Paser/article/details/89601875

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

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

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

猜你喜欢

转载自blog.csdn.net/Alpha_Paser/article/details/89601875