mysqlRDS | Oralce | MySQL

(002)mysql支持的数据类型总结

2016-01-21  本文已影响178人  林湾村龙猫

概述

mysql支持的数据分为3部分:

先扔一张大图做总结

mysql支持数据类型总结

数值类型

MySQL支持所有标准的SQL中的数值类型

1.整型数值

整数类型 字节数 最小值 ~ 最大值
tinyint 1 -128~127 或 0-255
smallint 2 -32768~32767 或 0~65535
mediumint 3 -8388608~8388607 或 0~1677215
int 4 -2147483648~2147483647 或 0~4294967295
bigint 8 -9223372036854775808~9223372036854775807 或 0~18446744073709551615

2.浮点数类型

浮点数类型 字节数 最小值~最大值
float 4 ±1.175494351E-38 ~ ± 3.402823466E+38
double 8 ±2.2250738585072014E-308 ~ ±1.7976931348623157E+308

3.定点数类型

定点数类型 字节数 描述
dec(m,d) m+2 最大取值范围与double相同,给定decimal的有效值取值范围由m和d决定

4.位类型

位类型 字节数 最小值~最大值
bit(m) 1~8 bit(1) ~ bit(64)

日期时间类型

时间日期类型 字节数 最小值~最大值
date 4 1000-01-01 ~ 9999-12-31
datetime 8 1000-01-01 00:00:00 ~ 9999-12-31 23:59:59
timestamp 4 19700101080001 ~ 2038年某个时刻
time 3 -838:59:59 ~ 838:59:59
year 1 1901 ~ 2155

字符串类型

字符串类型 字节数 描述
char(m) m m为0 ~ 255之间的整数
varchar(m) 值长度+1 m为0~65535之间的整数
tinytext 值长度+2 允许长度0~255字节
text 值长度+2 允许长度0~65535字节
mediumtext 值长度+3 允许长度0~167772150字节
longtext 值长度+4 允许长度0~4294967295字节
- - -
binary(m) m 允许0~m个字节定长的字符串
varbinary(m) 值长度+1 允许0~m个字节变长的字符串
tinyblob 值长度+1 允许长度0~255字节
blob 值长度+2 允许长度0~65535字节
mediumblob 值长度+3 允许长度0~167772150字节
longblob 值长度+4 允许长度0~4294967295字节
- - -
enum 1或2 1255个成员需要1个字节存;25565535个成员,2个字节存
set 1/2/3/4/8 类似enum,set一次可以选取多个成员,而enum只能一个

选择合适的数据类型

  1. char是固定长度,所以它的处理速度比varchar快得多,但缺点是浪费存储空间,不能在行尾保存空格。在MySQL中,MyISAM建议使用固定长度代替可变长度列;InnoDB建议使用varchar类型,因为在InnoDB中,内部行存储格式没有区分固定长度和可变长度。
  2. text与blob主要区别是text用来保存字符数据(如文章,日记等),blob用来保存二进制数据(如照片等)。blob与text在执行了大量删除操作时候,有性能问题(产生大量的“空洞“),为提高性能建议定期optimize table 对这类表进行碎片整理。
  3. 定点与浮点数,对于精度要求较高的地方,使用定点数。
  4. 日期选择原则是根据实际需求选择满足应用的最小存储日期类型。

参考

1.《深入浅出MySQL数据库开发、优化与管理(第2版)》
2.http://www.qttc.net/201207121.html
3.http://www.cnblogs.com/aoguren/p/3202097.html(图片来源)
4.http://blog.csdn.net/dba_waterbin/article/details/9006711(图片来源)

上一篇 下一篇

猜你喜欢

热点阅读