【MySQL】数据类型

  1. MySQL中的数据类型
  • 整数类型:TINYINT、SMALLINT、MEDIUMINT、INT(或INTEGER)、BIGINT
  • 浮点类型:FLOAT、DOUBLE
  • 定点数类型:DECIMAL
  • 位类型:BIT
  • 日期时间类型:YEAR、TIME、DATE、DATETIME、TIMESTAMP
  • 文本字符串类型:CHAR、VARCHAR、TINYTEXT、TEXT、MEDIUMTEXT、LONGTEXT
  • 枚举类型:ENUM
  • 集合类型:SET
  • 二进制字符串类型:BINARY、VARBINARY、TINYBLOB、BLOB、MEDIUMBLOBLONGBLOB
  • JSON类型:JSON对象、JSON数组
  1. 整数类型

整数类型一共有 5 种,包括 TINYINT、SMALLINT、MEDIUMINT、INT(INTEGER)和 BIGINT。

|-------------|----|-------------------------------------------|-------------------------|
| 整数类型 | 字节 | 有符号数取值范围 | 无符号数取值范围 |
| TINYINT | 1 | -128~127 | 0~255 |
| SMALLINT | 2 | -32768~32767 | 0~65535 |
| MEDIUMINT | 3 | -8388608~8388607 | 0~16777215 |
| INT、INTEGER | 4 | -2147483648~2147483647 | 0~4294967295 |
| BIGINT | 8 | -9223372036854775808~9223372036854775807 | 0~18446744073709551615 |

3.浮点类型

  • FLOAT 表示单精度浮点数;
  • DOUBLE 表示双精度浮点数;

4.定点数类型

  • 使用 DECIMAL(M,D) 的方式表示高精度小数。
  • 其中,M被称为精度,D被称为标度。0<=M<=65,0<=D<=30,D<M。例如,定义DECIMAL(5,2)的类型,表示该列取值范围是-999.99~999.99。
  • DECIMAL(M,D)的最大取值范围与DOUBLE类型一样,但是有效的数据范围是由M和D决定的。
  • DECIMAL 的存储空间并不是固定的,由精度值M决定,总共占用的存储空间为 M+2 个字节。也就是说,在一些对精度要求不高的场景下,比起占用同样字节长度的定点数,浮点数表达的数值范围可以更大一些。
  • 当DECIMAL类型不指定精度和标度时,其默认为DECIMAL(10,0)。当数据的精度超出了定点数类型的精度范围时,则MySQL同样会进行四舍五入处理。

5.位类型:BIT

  • BIT类型,如果没有指定(M),默认是1位。这个1位,表示只能存1位的二进制值。这里(M)是表示二进制的位数,位数最小值为1,最大值为64。
  1. 日期与时间类型
  • YEAR:通常用来表示年
  • DATE:通常用来表示年、月、日
  • TIME:通常用来表示时、分、秒
  • DATETIME:通常用来表示年、月、日、时、分、秒
  • TIMESTAMP:通常用来表示带时区的年、月、日、时、分、秒

|-----------|------|----|---------------------|-------------------------|------------------------|
| 类型 | 名称 | 字节 | 日期格式 | 最小值 | 最大值 |
| YEAR | 年 | 1 | YYYY或YY | 1901 | 2155 |
| DATE | 日期 | 3 | YYYY-MM-DD | 1000-01-01 | 9999-12-03 |
| TIME | 时间 | 3 | HH:MM:SS | -838:59:59 | 838:59:59 |
| DATETIME | 日期时间 | 8 | YYYY-MM-DD HH:MM:SS | 1000-01-01 00:00:00 | 9999-12-31 23:59:59 |
| TIMESTAMP | 日期时间 | 4 | YYYY-MM-DD HH:MM:SS | 1970-01-01 00:00:00 UTC | 2038-01-19 03:14:07UTC |

  1. 文本字符串类型

7.1 CHAR与VARCHAR类型

CHAR和VARCHAR类型都可以存储比较短的字符串。

|------------|------|----|-------------------|----------------|
| 字符串类型 | 特点 | 长度 | 长度范围 | 占用的存储空间 |
| CHAR | 固定长度 | M | 0 <= M <= 255 | M个字节 |
| VARCHAR(M) | 可变长度 | M | 0 <= M <= 65535 | (实际长度 + 1) 个字节 |

7.2 TEXT类型

|------------|-----------|----|-----------------------|----------|
| 文本字符串类型 | 特点 | 长度 | 长度范围 | 占用的存储空间 |
| TINYTEXT | 小文本、可变长度 | L | 0 <= L <= 255 | L + 2个字节 |
| TEXT | 文本、可变长度 | L | 0 <= L <= 65535 | L + 2个字节 |
| MEDIUMTEXT | 中等文本、可变长度 | L | 0 <= L <= 16777215 | L + 3个字节 |
| LONGTEXT | 大文本、可变长度 | L | 0 <= L<= 4294967295 | L + 4个字节 |

  1. ENUM类型
  • ENUM类型也叫作枚举类型,ENUM类型的取值范围需要在定义字段时进行指定。设置字段值时,ENUM类型只允许从成员中选取单个值,不能一次选取多个值。
  • 其所需要的存储空间由定义ENUM类型时指定的成员个数决定。
  1. SET类型
  • SET表示一个字符串对象,可以包含0个或多个成员,但成员个数的上限为64 。设置字段值时,可以取取值范围内的 0 个或多个值。
  • 当SET类型包含的成员个数不同时,其所占用的存储空间也是不同的
  1. 二进制字符串类型
  • MySQL中的二进制字符串类型主要存储一些二进制数据,比如可以存储图片、音频和视频等二进制数据。
  • MySQL中支持的二进制字符串类型主要包括BINARY、VARBINARY、TINYBLOB、BLOB、MEDIUMBLOB 和LONGBLOB类型。
  1. JSON 类型
  • JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。它易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。
相关推荐
掘根2 小时前
【网络】高级IO——poll版本TCP服务器
网络·数据库·sql·网络协议·tcp/ip·mysql·网络安全
Bear on Toilet3 小时前
初写MySQL四张表:(3/4)
数据库·mysql
无妄啊______3 小时前
mysql笔记9(子查询)
数据库·笔记·mysql
Looooking3 小时前
MySQL 中常用函数使用
数据库·mysql
island13144 小时前
从 InnoDB 到 Memory:MySQL 存储引擎的多样性
数据库·学习·mysql
ZZDICT4 小时前
MySQL 子查询
数据库·mysql
柳鲲鹏4 小时前
编译成功!QT/6.7.2/Creator编译Windows64 MySQL驱动(MinGW版)
开发语言·qt·mysql
一个很帅的帅哥5 小时前
实现浏览器的下拉加载功能(类似知乎)
开发语言·javascript·mysql·mongodb·node.js·vue·express
dbln5 小时前
MySQL之表的约束
数据库·mysql
白总Server5 小时前
MySQL在大数据场景应用
大数据·开发语言·数据库·后端·mysql·golang·php