所谓的数据类型:对数据进行统一的分类,从系统的角度出发为了能够使用统一的方式进行管理,更好的利用有限的空间。
SQL中将数据类型分成了三大类:数值类型,字符串类型和时间日期类型。
1、数值型
数值型数据:都是数值。系统将数值型分为整数型和小数型
1.1整数型
存放整型数据,在SQL中因为更多要考虑如何节省磁盘空间,所以系统将整型又细分成了5类:
Tinyint 迷你整型:使用一个字节存储.表示的状态最多为256种(常用)
Smallint 小整型:使用2个字节存情.表示的状态最多为65536种
Mediumint:中整型.使用3个字节存储
Int:标准整型,使用4个字节存储(常用)
Bigint:大整型,使用8个字节存储
创建一张整形表:
-- 创建整型表
create table my_int(
int_1 tinyint,
int_2 smallint,
int_3 int,
int_4 bigint
)charset utf8;
插入数据:只能插入整型,并且只能插入范围内的整型
-- 插入数据
insert into my_int values(100,100,100,100); --有效数据
insert into my_int values('a','b','199','f'); -- 无效数据:类型限定
insert into my_int values(255,10000,10000,10000); -- 错误:超出范围
注:ERROR 1064指的是语法错误
SQL中的数值类型全部都是默认有符号:分正负
有时候需要使用无符号数据,需要给数据类型限定:intunsigned,无符号,从0开始
-- 给表增加一个无符号类型
alter table my_int add int_5 tinyint unsigned; --无符号类型
-- 插入数据
insert into my_int values(127,1000,10000,1000000,255);
查看表结构的时候.发现每个字段的数据类型之后都会自带一个括号.里面有指定的数字
显示宽度:没有特别的含义、只是默认的告诉用户可以显示的形式而已,实际上用户是可以控制的.这种控制不会改变数据本身的大小.
alter table my_int add int_6 tinyint(1) unsigned; -- 指定显示宽度为1;
desc my_int;
insert into my_int values(127,0,0,0,255,255);
select * from my_int;
显示宽度的意义-在于当数据不够显示宽度的时候,会自动让数据变成对应的显示宽度
-通常需要搭配一个前导0来增加宽度.不改变值大小-zerofill(零填充)-零填充会导致数值自动变成无符号
alter table my_int add int_7 tinyint(2) zerofill; -- 指定显示宽度为2,不够则用0填充,超出则不管
零填充+显示宽度的效果:
零填充的意义(显示宽度):保证数据格式
1.2小数型
小数型:带有小数点或者范围超出整型的数值类型。(浮点型属于小数型,浮点型有精度丢失)
SQL中将小数型分成两种:浮点型和定点型
浮点型:小数点浮动,精度有限,而且会丢失精度 定点型:小数点固定,精度固定,不会丢失精度
1.2.1浮点型
浮点型数据时一种精度型数据,因为超出指定范围之后,会丢失精度(自动四舍五入)。理论分为两种精度。
float:单精度,占用4个字节存储数据,精度范围大概为7位左右
double:双精度,占用8个字节存储数据,精度方位大概为15位左右
创建浮点数表:浮点的使用方式-直接float表示没有小数部分:float(M,D):M代表总长度,D代表小数部分长度,整数部分长度为M-D
-- 浮点数表
create table my_float(
f1 float,
f2 float(10,2), -- 10位在精度范围之外
f3 float(6,2) -- 6位在精度范围之内
)charset utf8;
插入数据:可以直接是小数,也可以是科学计数法
-- 插入数据(符合条件)
insert into my_float values(1000.10,1000.10,1000.10);
insert into my_float values(1234570000,12345678.90,1234.56);
insert into my_float values(3e38,3.01e7,1234.56);
insert into my_float values(9999999999,99999999.99,9999.99); -- 最大值
浮点型数据的插入:整数部分是不能超出长度的,但是小数部分可以超出长度(系统会自动四舍五入)
-- 插入数据(超出范围)
insert into my_float values(123456,1234.12345678,123.9876543); -- 小数部分超出
insert into my_float values(123456,1234.12,12345.56); -- 整数部分超出
结果:浮点数一定会进行四舍五入(当超出精度范围)-浮点数如果因为系统进位导致整数部分超出指定的长度,那么系统允许成立。
1.2.2定点型
定点型:绝对的保证整数部分不会被四舍五入(不会丢失精度),小数部分有可能(理论小数部分也不会丢失精度)
创建定点数表:以浮点数为对比
-- 创建定点数表
create table my_decimal(
f1 float(10,2),
d1 decimal(10,2)
)charset utf8;
插入数据:定点数的整数部分一定不能超出长度(进位不可以),小数部分的长度可以随机超出(系统自动四舍五入)
-- 插入数据
insert into my_decimal values(12345678.90,12345678.90); -- 有效数据
insert into my_decimal values(1234.123456,1234.123456); -- 小数部分超出,数据有效
-- 查看警告
show warnings;
浮点数如果进位导致长度溢出没有问题,但是定点数不行
-- 插入数据
insert into my_decimal values(99999999.99,99999999.99); -- 没有问题
insert into my_decimal values(99999999.99,99999999.999); -- 进位超出范围
-- 查看数据效果:
select * from my_decimal;
2、时间日期类型
注:Time中:-指负,+指正。year(2):1970-2069
创建时间日期表:
-- 创建时间日期表
create table my_date(
d1 datetime,
d2 date,
d3 time,
d4 timestamp,
d5 year
)charset utf8;
-- 插入数据
insert into my_date values('2015-9-28 11:50:36','2015-9-28','11:50:54','2015-9-28 11:51:08',2015);
-- 时间使用负数
insert into my_date values('2015-9-28 11:50:36','2015-9-28','-11:50:54','2015-9-28 11:51:08',2015);
insert into my_date values('2015-9-28 11:50:36','2015-9-28','-211:50:54','2015-9-28 11:51:08',2015);
insert into my_date values('2015-9-28 11:50:36','2015-9-28','-2 11:50:54','2015-9-28 11:51:08',2015);-- -2指的是过去两天,会换算成48(小时)
-- year可以使用2位或者4位
insert into my_date values('2015-9-28 11:50:36','2015-9-28','11:50:54','2015-9-28 11:51:08',69);
insert into my_date values('2015-9-28 11:50:36','2015-9-28','11:50:54','2015-9-28 11:51:08',70);
通过函数可以获取到真正的时间戳: