MySQL基础01-数据类型

一、整数类型

每个整型类型可以指定一个最小显示宽度(注意:这个宽度并不表示存储的值有多大)

类型 存储空间(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 著

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章