1、MySQL数据类型
·整型:
tinyint、INT、smallint、mediumint、bigint
int(21)和int(11)本质是无区别的,只有在补零显示是有区别
create table t(a int(11) zerofill,b int(21) zerofill);
#zerofill表示补零
insert into t values(1,1);
select * from t;
·浮点型
FLOAT(M,D) 单精度, DOUBLE(M,D)双精度,double类型精度高于float,但是都会造成精度丢失,如:
create table t (id int,a float(7,4),b double(6,4));
insert into t (id ,a,b) values(1,123.12345,78.876598);
select * from t where id=1;
查询结果如下
出现了四舍五入,精度丢失的情况,如果数据是和money有关的话,就有意思了
decimal 高精度数据类型,decimal(M,N) M为总精度,N为小数点位数,1<M<254,0<N<60,存储空间变长,
经验总结
·存储性别、省份、类型等分类信息时优先使用tinyint、enum
·BIGINT存储空间更大,int和bigint之间通常使用bigint
·交易等高精度数据时选择decimal
·字符串型
char、varchar、text、blog、binary
char与varchar
·char和varchar的存储单位都是字符
字符与字节的区别
字节是计算机中表示数据的存储单位,字符是一个符号,
char 存储定长,容易造成空间的浪费
varchar存储变长,可以节省存储空间,用多少存多少
text与char、varchar的区别
·char和varchar的存储单位为字符
·text存储单位为字节,总大小为65535字节,约为64kb
·char数据类型最大为255字符
·varchar数据类型为变长存储,可以存储超过255字符
·text在数据库内部大多存储为溢出页,效率不如char
blog、binary存储图片音频,如头像,
虽然可以,但是非常不推荐
经验总结
·char与varchar定义的长度是字符长度不是字节长度
·存储字符串推荐选择使用varchar
·虽然数据库可以存储二进制数据,但性能低下,不要使用数据库存储文件音频等二进制数据
·日期型
date、dateTime、Timestamp、Time、Year
时间类型的区别
·存储空间的区别
date三字节,如:2015-05-01
time三字节,如: 11:12:00
TimeStamp四字节,如:2015-05-01 11:12:00
DateTime 八字节,如:2015-05-01 11:12:00
·存储精度的区别
Date精确到年月日
Time精确到小时分钟秒
timestamp、DateTime都包含上述两者
timestamp与DateTime区别
timestamp存储范围:1970-01-01 00:00:01 to 2038-01-19 03:14:07
DateTime存储范围:1000-01-01 00:00:00 to 9999-12-31 23:59:59
字段类型和时区的关系
timestamp会根据系统时区进行转变,datetime不会
国际化系统使用timestamp,如:
create table t (a_datetime datetime,b_timestamp timestamp);
#插入当前系统时间
insert into t values(now(),now());
select * from t;
#重置系统时间
set time_zone= '+00:00';
select * from t;
#结果显示timestamp类型的时间随着时区改变而改变,
#改回系统时间
set time_zone='+08:00';
bigint 也可以存储时间类型
bigint存储时间时,需要应用程序,将时间转为数字
经验总结
date和Time类型精度交差
bigint类型一样可以存储时间
数据类型选择,按需选择
·其他数据类型:BINARY、VARBINARY、ENUM、SET、