一、整数类型
每个整型类型可以指定一个最小显示宽度(注意:这个宽度并不表示存储的值有多大)
类型 | 存储空间(N) | 取值范围:-2(N-1)到 2(N-1)-1 |
---|---|---|
TINYINT | 8 | -128……127 |
SMALLINT | 16 | -32768……32767 |
MEDIUMINT | 24 | -8388608……8388607 |
INT | 32 | -2147483648……2147483647 |
BIGINT | 64 | (自己算... ...) |
注:如果有指定UNSIGNED属性,则存取范围可以提升一倍,
即:-2N到 2N-1
基本格式:
INT[(M)] [UNSIGNED] [ZEROFILL]
① M:指定显示宽度(默认是M=10),以实际的取值范围为准,值超过显示宽度,显示宽度自动增加
② unsigned:无符号的,表示只允许正数,所以取值范围取绝对值且最大值*2
③ zerofill: 填充0(如果声明了zerofill,该列会自动设为unsigned)
二、实数类型
1、定点小数:decimal
基本格式:
DEC[(M[,D])] [UNSIGNED] [ZEROFILL]
① M:精度,(整数位数+小数位数)不包含小数点的数字总位数(1--30),不指定默认为10
② D:小数位数,如果不指定,默认为0
注: 若位数不够,小数末尾补零;若位数超预算,则报错。
2、浮点数:float与double
基本格式:
float[(length) | (<display width>,<scale>)]
double[(precision) | (<display width>,<scale>)]
两者区别在于值所保留的存储空间数量不同
注:由于对一个浮点数字来说,可用的存储空间有限,如果一个数字非常大或非常小,将存储这个数字的近似值而不是实际值。
使用方法:
① 使用一个参数来指定浮点类型
length/precision:在一个浮点数据类型中可以指定长度,来确定具体的浮点类型。
0~24:单精度float,从第7位有效位,进行四舍五入存储
25~30:双精度double,从第16位有效位,进行四舍五入存储
如:
mysql> create table t3(id float(8));
//m=8,说明是单精度,存储6位的近似值(第7位四舍五入,后面为0)
mysql> insert into t3 values(123);
mysql> insert into t3 values(1234567);
mysql> insert into t3 values(123456789);
mysql> insert into t3 values(123456789.123456789);
mysql> select * from t3;
+-----------+
| id |
+-----------+
| 123 |
| 1234570 |
| 123457000 |
| 123457000 |
+-----------+
② 使用两个参数来指定浮点类型
单精度float(m,d):m表示精度(0~24),d表示小数位数
双精度double(m,d):m表示精度(25~30),d表示小数位数
注意:整数位(m-d)不够没关系,超出报错;小数位(d)不够补零,超出四舍五入。
三、字符串
类型 | 描述 |
---|---|
char(n) | 固定长度,最多255个字符。char非常适合用于存储密码的MD5值 |
varchar(n) | 可变长度,最多65535个字符。varchar需要使用1或2个额外字节记录字符串长度:如果列的最大长度小于或等于255字节,则使用1个字节表示,否则使用2个字节。 |
TEXT | 包括TINYTEXT、SMALLTEXT(TEXT)、MEDIUMTEXT、LONGTEXT |
BLOB | 包括TINYBLOB、SMALLBLOB(BLOB)、MEDIUMBLOB、LONGBLOB,二进制类型。BLOB 可以储存图片。 |
1、char和varchar
区别:
① char(n) 若存入字符数小于n,则以空格补于其后,查询之时再将空格去掉。所以char类型存储的字符串末尾不能有空格,varchar不限于此。
② char(n) 固定长度,char(4)不管是存入几个字符,都将占用4个字节,varchar是存入的实际字符数+1个字节(n<=255)或2个字节(n>255),所以varchar(4),存入3个字符将占用4个字节。
③ char类型的字符串检索速度要比varchar类型的快。
④ 对于经常更变的数据,char比varchar更好,char不容易产生碎片。
相同:
① 如果存储内容走出指定长度,都会被截断。
2、varchar和text的区别:
① varchar可指定n,text不能指定,内部存储varchar是存入的实际字符数+1个字节(n<=255)或2个字节(n>255),text是实际字符数+2个字节。
② text类型不能有默认值。
③ varchar可直接创建索引,text创建索引要指定前多少个字符。varchar查询速度快于text,在都创建索引的情况下,text的索引似乎不起作用。
④ char和varchar可以有默认值,text不能指定默认值。
注:尽量避免使用BLOB/TEXT类型,查询会使用临时表,导致严重的性能开销。
四、枚举
枚举可以把一些不重复的字符串存储成一个预定的集合。MySQL在存储枚举时非常紧凑,会根据列表值的数量压缩到一个或者两个字节中。MySQL在内部会将每个值在列表中的位置保存为整数,并且在表的.frm文件中保存“数字 - 字符串”映射关系的“查找表”。
注:尽量避免使用数据作为ENUM枚举的常量,易混乱。
五、时间和日期
类型 | 描述 |
---|---|
DATETIME | 表示时间范围是1001年到9999年,精度为秒。占用8个字节。 |
TIMESTAMP | 占用4个字节,表示时间范围从1970年到2038年。使用该类型时一定要注意时区问题。 |
六、位
位主要是用来存放二进制数,select查询默认显示10进制,可以使用bin()、hex()函数来进行查询。
bin()---显示二进制格式
hex()---显示十六进制格式
如:
mysql> create table t(id bit(4));
mysql> insert into t values(2);
mysql> insert into t values(13);
mysql> select bin(id),hex(id) from t;
+---------+---------+
| bin(id) | hex(id) |
+---------+---------+
| 10 | 2 |
| 1101 | D |
+---------+---------+
参考
《高性能MySQL》 [美]Baron Scbwartz, Peter Zaitsev, Vadim Tkacbenko 著