二、 Schema与数据类型优化

20210112 02:30-03:40整理
【素还真】诗号:
半神半圣亦半仙,全儒全道是全贤;
脑中真书藏万卷,掌握文武半边天。

选择优化的数据类型

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

);

INSERT INTO enum_test(e) VALUES('fish'),('dog'),('apple');

mysql 选择类型存数组_mysql