美文网首页
MySQL数据类型

MySQL数据类型

作者: 娑婆诃 | 来源:发表于2016-04-27 02:41 被阅读0次

    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、

    相关文章

      网友评论

          本文标题:MySQL数据类型

          本文链接:https://www.haomeiwen.com/subject/fkmqrttx.html