MySQL数据类型

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;

MySQL数据类型_第1张图片

·浮点型    

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;

查询结果如下

MySQL数据类型_第2张图片

出现了四舍五入,精度丢失的情况,如果数据是和money有关的话,就有意思了

decimal  高精度数据类型,decimal(M,N) M为总精度,N为小数点位数,1

经验总结

    ·存储性别、省份、类型等分类信息时优先使用tinyint、enum

     ·BIGINT存储空间更大,int和bigint之间通常使用bigint

      ·交易等高精度数据时选择decimal

·字符串型

char、varchar、text、blog、binary

char与varchar

    ·char和varchar的存储单位都是字符

     字符与字节的区别

字节是计算机中表示数据的存储单位,字符是一个符号,

MySQL数据类型_第3张图片
MySQL数据类型_第4张图片

char 存储定长,容易造成空间的浪费

varchar存储变长,可以节省存储空间,用多少存多少

MySQL数据类型_第5张图片

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;


MySQL数据类型_第6张图片

#重置系统时间

set time_zone= '+00:00';

select * from t;

#结果显示timestamp类型的时间随着时区改变而改变,

MySQL数据类型_第7张图片

#改回系统时间

set time_zone='+08:00';

bigint 也可以存储时间类型

bigint存储时间时,需要应用程序,将时间转为数字

经验总结

date和Time类型精度交差

bigint类型一样可以存储时间

数据类型选择,按需选择

·其他数据类型:BINARY、VARBINARY、ENUM、SET、

你可能感兴趣的:(MySQL数据类型)