美文网首页
数据库日期字段采用String或Date等原生类型的优劣势对比

数据库日期字段采用String或Date等原生类型的优劣势对比

作者: 大鱼炖海棠 | 来源:发表于2019-05-16 22:30 被阅读0次

    数据库中常用的日期类型:

    日期类型 存储空间 日期格式 日期范围
    date 3 bytes YYYY-MM-DD 1000-01-01 ~ 9999-12-31
    datetime 8 bytes YYYY-MM-DD HH:MM:SS 1000-01-01 00:00:00 ~ 9999-12-31 23:59:59
    timestamp 4 bytes YYYY-MM-DD HH:MM:SS 1970-01-01 00:00:01 ~ 2037-12-31 23:59:59
    time 3 bytes HH:MM:SS -838:59:59 ~ 838:59:59
    varchar 14+ bytes YYYYMMDDHHMMSS

    字符串不是一个很高效的数据类型,占用存储空间大,数值之间compare是逐个字符比对,比较慢,唯一的优势是展示比较直接。

    timestamp和其他数据库原生支持的日期类型,它们在实际存储和查询的时候其实都是整数,所以非常高效。相对于varchar占用的的内存也更少。

    小结:数据库存储日期,建议采用原生的日期类型,效率和功能上肯定都有很高的保证;如果不支持日期类型的话,就用长整型Long或者大整数BIGINT。采用varchar存储是一种比较偷懒的做法,但是考虑到代码可能要移植到不同的数据库上,在兼容性上有更高的保证。

    相关文章

      网友评论

          本文标题:数据库日期字段采用String或Date等原生类型的优劣势对比

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