二、 Schema与数据类型优化
20210112 02:30-03:40整理
【素还真】诗号:
半神半圣亦半仙,全儒全道是全贤;
脑中真书藏万卷,掌握文武半边天。
选择优化的数据类型
- 选择原则:
① 更小的通常更好—应该尽量使用可以正确存储数据的最小数据类型
② 简单就好—简单的数据类型的操作通常需要更少的CPU周期
③ 尽量避免NULL—如果查询中包含NULL的列,对MySQL来说更难优化,因为为null的列是的索引、索引统计和值比较都更为复杂 - 整数类型
① 两种类型的数字:整数和实数
② 整数类型:TINYINT/SAMLLINT/MEDIUMINT/INT/BIGINT分别使用8/16/24/32/64位存储空间,它们存储的值得范围从-2(N-1)到2(N-1)-1,N是存储空间的位数
③有符号和无符号类型使用相同的存储空间,并且具有相同的性能 - 实数类型
① 实数hi带有小数部分的数字
② FLOAT和DOUBLE类型支持使用标准的浮点运算进行近似计算;DECIMAL类型用于存储精确的小数 - 字符串类型
① VARCHAR 和CHAR是两种最主要的字符串类型。
② VARCHAR类型用于存储可变长字符串,它比定长类型更节省空间,因为它只使用有必要的空间
③ VARCHAR需要使用1或2个额外字节记录字符串的长度(如果列的最大长度小于或等于255,则使用1个字节,否则2个字节)
④ CHAR类型是定长的;当存储CHAR值时,末位空格会被删除掉
⑤ 数据存储取决于存储引擎,并非所有的存储引擎都会按照相同的方式处理定长和变长的字符;Memory引擎只支持定长的行,即使有变长字段也会根据最大的长度分配空间 - BLOB和TEXT类型
① 都是为存储很大的数据而设计的字符串数据类型,分别采用二进制和字符方式存储
② MySQL把每个BLOB和TEXT值当做一个独立的对象处理。当值过大,InnoDB会使用专门的“外部”存储区域来进行存储,此时每个值在行内需要1~4个字节存储一个指针,然后在外部区域存储实际的值
③ Memory引擎不支持BLOB和TEXT类型 - 使用枚举类型代替字符串
① 把一些不重复的字符串存储成一个预定义的集合
CREATE TABLE enum_test(
e ENUM('fish','apple','dog') NOT NULL
);
INSERT INTO enum_test(e) VALUES('fish'),('dog'),('apple');