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;

·浮点型    

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、

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本文基于MySQL5.6版本进行描述从大的方面来讲,MySQL的数据类型分为4种 数值类型 日期和时间 字符串类型...
    黑哥儿666阅读 784评论 0 0
  • sql 将数据类型分为三大类:数值类型,字符串,日期时间型 一、数值型: 数值大类:整数型和小数型 整数型 整数型...
    陈智涛阅读 1,062评论 0 0
  • MySQL不同存储引擎可能会有不同。下面的内容以InnoDB为主。 选择数据类型的步骤 确定合适的大类型:数字、字...
    linjinhe阅读 1,751评论 0 3
  • 所谓的数据类型:对数据进行统一的分类,从系统的 角度出发为了能够使用统一的方式进行管理,更好的利用有限的空间;SQ...
    coder_hong阅读 637评论 0 0
  • 太阳闭上眼睛 风,歇斯底里地狂吼 惊吓了树 掉了叶,断了枝 变成一间劫后的房屋 地铁关上车门 手,条件反射地活跃 ...
    仔萄阅读 916评论 0 3