在后端开发中经常会碰到涉及数据库的场景,不知道屏幕前的你有这样的疑惑没有,每每在遇到时间、日期字段总是让人头疼,分不清到底是选date还是datetime,亦或是timestamp,真是抓耳挠腮啊,怎么办呐,大都翻看之前的表结构,把之前的时间、日期类型抄过来,草草了事。以至于在后面的开发中总是为时间、日期类型做特殊处理,过后便不再理会这事了,今天就把这事一次性说明白。
1.mysql时间戳
在mysql中表示日期和时间的数据类型,大体上有下面几种,
名称 |
定义方式 |
格式 |
范围 |
date |
date |
YYYY-MM-DD |
'1000-01-01' to '9999-12-31' |
time |
time[.fraction] |
hh:mm:ss[.000000] |
'-838:59:59.000000' to '838:59:59.000000' |
datetime |
datetime[.fraction] |
YYYY-MM-DD hh:mm:ss[.000000] |
'1000-01-01 00:00:00' to '9999-12-31 23:59:59' |
timestamp |
timestamp[.fraction] |
YYYY-MM-DD hh:mm:ss[.000000] |
'1970-01-01 00:00:01' UTC to '2038-01-19 03:14:07' UTC |
year |
year |
YYYY |
'1901' to '2155' |
注意在上面的表格中,我把日期和时间分开进行了描述,主要是因为在很多场景中很容易把这两个词当作同一个意思,在这里时间指的时分秒,日期指的是年月日。
比较常用的有date、datetime、timestamp,今天就对这三种表示日期和时间的类型进行分析,看下在实际开发过程中如何选择?
2.日期/时间类型
(1)date
date仅包含日期,mysql存储和显示的格式是'YYYY-MM-DD',可以表示的范围是'1000-01-01' to '9999-12-31'
(2)datetime
datetime包含日期、时间两部分,mysql存储和显示的格式是'YYYY-MM-DD hh:mm:ss',可以表示的范围是'1000-01-01 00:00:00' to '9999-12-31 23:59:59'
(3)timestamp
timestamp包含日期、时间两部分,在存储时存储的是时间戳,可以表示的范围是'1970-01-01 00:00:01' UTC to '2038-01-19 03:14:07' UTC,这里需要注意timestamp是有时区概念的,该类型可跟随时区变化,默认情况下是服务器的时区,如果一个数据库连接设置了时区参数,那么该类型的值会根据连接设置的时区来存储和返回值。
上面介绍了date、datetime、timestamp这三种数据类型,还有一个点需要着重强调,datetime、timestamp是可以有小数位的,一共可以有6位,所以在定义是可以是datetime(3),要说明的是默认情况下是datetime(0),由于是0所以通常情况下就倍省略了;
本文主要分享了,mysql中常见的日期、时间数据类型,下面几条需谨记,datetime、timestamp都可以满足需求的情况下,优先选择datetime,因为其表示的范围更大;格式化方式为'YYYY-MM-DD hh:mm:ss[.000000]',在进行插入的时候使用的是相应的字符串的格式进行插入;自动初始化和更新语句要牢记,'dt datetime not null default current_timestamp on update current_timestamp';current_timestamp可以写成current_timestamp(0);标识记录的新增或更新时间的字段,设置为数据“default current_timestamp on update current_timestamp‘更省心;