MySQL数据类型选择

模式流沙
• 阅读 5416

当一个列可以选择多种数据类型时,应该优先选择数字类型,其次是日期或二进制类型,最后是字符类型。越简单的数据类型,需要的处理资源就越少。
对于相同级别的数据类型,应该优先选择占用空间小的数据类型。因为在数据库中,数据处理是以页为单位的,每个页存储的数据量是一定的(Innodb一页是16K),列的长度越小,单页能容纳的行数就越多。这有利于减少磁盘IO,提高数据库性能。
最好指定列为NOT NULL。可为NULL的列对MySQL来说很难优化,因为可为NULL的列使得索引、索引统计和值比较都更复杂。可为NULL的列也会占用更多的存储空间。

整数类型

MySQL数据类型选择

注意,MySql虽然可以为整数指定宽度,例如int(11),但是这没有任何意义,它并不会限制值的合法范围

实数类型

MySQL数据类型选择

可以利用DECIMAL存储比BIGINT还大的整数。
CPU不支持对DECIMAL的直接计算,是MySQL自身实现了对DECIMAL的高精度计算。MySQL将DECIMAL类型的数字用二进制字符串存储,每4个字节存9个数字。例如,DECIMAL(18,9)小数点两边各存储9个数字,所以小数点两边各占用4个字节,再加上小数点本身占用1个字节,总共占用9个字节。DECIMAL类型的计算效率没有DOUBLE和FLOAT高。
MySQL使用DOUBLE作为内部浮点计算类型。
因为DECIMAL类型需要比较大的空间和计算开销,所以应该只在对小数进行精确计算时才使用DECIMAL。

VARCHAR和CHAR类型

varchar类型用于存储可变长字符串,它只占用必要的存储空间。
varchar需要使用1或2个额外字节记录字符串的长度:如果字符串的最大长度小于255则只占用1个字节用于记录字符串长度,如果字符串的长度大于255则要占用2个字节用于记录字符串的长度。这就代表varchar的最大长度就是65535。但是在实际中varchar列不能达到65535这么大,因为对innodb来说,65535是一行中所有varchar列共享的长度。
下面的这些情况使用varchar类型是合适的:

  1. 字符串的最大长度比平均长度大很多

  2. 列的更新很少。这是因为行是变长的,在update时可能使行变的比原来更长。如果行占用的空间增长,并且在页内没有更多的空间可以存储,就需要存储引擎特别的处理。例如,Innodb存储引擎需要分裂页使行放入页内。这会导致增加内存碎片,降低数据库性能。

char类型是定长的。它的最大宽度为255。
char类型字符串末尾的空格会被删除。
下面的这些情况使用char类型是合适的:

  1. 存储很短的字符串,或者所有字符串长度都比较接近。短字符串用char类型存储比用varchar类型效率要高。

  2. 经常变更的数据。因为char类型是定长的,对其变更不会产生内存碎片。

varchar和char的宽度都是以字符为单位的。两种类型相比,char类型会去掉字符串末尾的空格,而varchar类型不会。

VARCHAR(5)和VARCHAR(20)存储hello的空间开销是一样的,那么使用更短的列有什么优势吗?
有很大的优势。MySql通常会分配固定大小的内存块存储内部值。虽然varchar类型在磁盘上是采用变长的方式存储,但在内存中存储varchar类型字符串使用的是其最大宽度。所以更长的列会消耗更大的内存。应该只分配真正需要的空间。

日期和时间类型

MySql能存储的最小时间粒度为秒,但是MySql可以使用微妙级别的粒度进行临时运算。
DATETIME类型
DATETIME可以保存从1001年到9999年之间的时间值,精度为秒,占用8个字节的存储空间。它将时间值保存到格式为YYYYMMDDHHMMSS的整数中,保存的时间值与时区无关
TIMESTAMP类型:
TIMESTAMP就是时间戳,它保存了从1970年1月1日零点以来的秒数,与UNIX时间戳值相同。TIMESTAMP只占用4个字节的存储空间,表示的时间范围只能从1970年到2038年。
TIMESTAMP显示的值依赖于时区,下面例子展示了在不同的时区下TIMESTAMP类型的值会有变化。
MySQL数据类型选择

创建的test_date表分别包含了timestamp类型的列和datatime类型的列。通过set time_zone='+10:00'命令设置时区。向表中插入一行记录,两个列的值都是当前时间。通过select语句查看结果,两种不同类型列的值是相同的。再通过set time_zone='-10:00'命令修改时区,从第二次select语句的执行结果可以看到,timestamp类型列的值已经改变了,而datetime类型列的值没有改变。
timestamp还有datetime没有的特殊属性,默认情况下,如果insert时没有指定第一个timestamp类型列的值时,MySql会自动设置这个列的值为当前时间。在更新一行记录时,MySql也会自动更新timestamp类型列的值。
MySQL数据类型选择

可以从例子中看到,MySql会自动给timestamp类型的列用当前时间赋值。而datetime类型的列不会。

MySQL数据类型选择

当更新列时,timestamp类型的列也会自动更新成当前时间。

标识列的类型选择

标识列可能会和其它值进行比较(如在关联操作中),或者根据标识列寻找其它列。标识列也可能作为其它表的外键使用。所以为标识列选择恰当的数据类型非常重要。
整数类型是标识列最好的选择,因为整数计算很快并且可以AUTO_INCREMENT。
应该尽可能避免采用字符串类型作为标识列。因为字符串类型很消耗空间,并且计算比数字类型要慢。

点赞
收藏
评论区
推荐文章
CuterCorley CuterCorley
4年前
C语言入门系列之2.数据类型、运算符和表达式
一、数据类型C语言常见数据类型如下:1.数据类型基本数据类型基本数据类型最主要的特点是,其值不可以再分解为其他类型。也可以说,基本数据类型是自我说明的。构造数据类型构造数据类型是根据已定义的一个或多个数据类型用构造的方法来定义的。也就是说,一个构造类型的值可以分解成若干个“成员”或“元素”。每个“成员”都是一个基本数据类型或
LinMeng LinMeng
4年前
js之传值与传址/undefined和null/严格模式
传值与传址基本数据类型有五种Undefined、Null、Boolean、Number和String引用数据类型有两种object,array,fn两种数据类型的区别:1.存储位置不同原始数据类型直接存储在栈(stack)中简单数据段,占据空间小,大小固定,属于被频繁使用的数据,所以存储在栈中;引用数据类型直接存
Gloria36 Gloria36
4年前
MySQL数据类型详解和存储机制
1.1数据类型概览数据类型算是一种字段约束,它限制每个字段能存储什么样的数据、能存储多少数据、能存储的格式等。MySQL/MariaDB大致有5类数据类型,分别是:整形、浮点型、字符串类型、日期时间型以及特殊的ENUM和SE
Wesley13 Wesley13
3年前
Java对象的浅拷贝和深拷贝&&String类型的赋值
Java中的数据类型分为基本数据类型和引用数据类型。对于这两种数据类型,在进行赋值操作、方法传参或返回值时,会有值传递和引用(地址)传递的差别。浅拷贝(ShallowCopy):①对于数据类型是基本数据类型的成员变量,浅拷贝会直接进行值传递,也就是将该属性值复制一份给新的对象。因为是两份不同的数据,所以对其中一个对象的该成员变量值进行修改,
Wesley13 Wesley13
3年前
Mysql系列第二讲 详解mysql数据类型(重点)
Mysql系列第二讲MySQL的数据类型整数类型示例1:有符号类型示例2:无符号类型类型(n)说明示例1(重点)示例2日期类型字符串类型mysql类型和java类型对应关系数据类型选择的一些建议MySQL的数据类型
Wesley13 Wesley13
3年前
Oracle数据类型
Oracle的数据类型有二十多种,包括字符串类型、数字类型、日期类型、LOB类型、LONGRAW&RAW类型、ROWID&UROWID类型。太多的数据类型很容易让初学者感到迷茫,在本文中,我将以程序员的视角,结合实际开发的需求来介绍Oracle的数据类型。Oracle的数据类型虽然很多,但实用的只有以下几种:1)字符串类型:char和varc
Wesley13 Wesley13
3年前
Mysql 数据类型、约束类型
mysql数据类型MySQL中定义数据字段的类型对你数据库的优化是非常重要的。MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。数值类型MySQL支持所有标准SQL数值数据类型。这些类型包括严格数值数据类型(INTEGER、SMALLINT、DECIMAL和NUME
Stella981 Stella981
3年前
Redis 入门概述
1\.什么是redisRedis是用C语言开发的一个开源的高性能键值对(keyvalue)数据库。它通过提供多种键值数据类型来适应不同场景下的存储需求,目前为止Redis支持的键值数据类型如下:字符串类型【String】散列类型【Hash】列表类型【List】集合类型【Set】有序集合类型【
Wesley13 Wesley13
3年前
MySQL数据类型全解析
1概述本文主要介绍了MySQL的各种数据类型,版本为8.x,MySQL的数据类型可以分为六类:数值类型,日期时间类型,字符串类型,二进制类型,JSON类型与空间数据类型.2数值类型数值类型是最基本的类型,可以分为整数类型与浮点数类型.2.1整型类型字节数无符号范围有符号范围TI
Wesley13 Wesley13
3年前
MySQL数据库DDL、DML详解
一、MySQL数据库数据类型<1MySQL数据库中支持多种数据类型数值型字符型日期型<2常用的数据类型整型int:整型,存储整数int(M):M表示预期值,与存储大小和数值的范围无关idi
小万哥 小万哥
1年前
SQL 日期处理和视图创建:常见数据类型、示例查询和防范 SQL 注入方法
SQL处理日期在数据库操作中,处理日期是一个关键的方面。确保插入的日期格式与数据库中日期列的格式匹配至关重要。以下是一些常见的SQL日期数据类型和处理方法。SQL日期数据类型MySQL日期数据类型DATE格式为YYYYMMDDDATETIME格式为YYYY