MySQL中日期时间类型与格式化 |
您所在的位置:网站首页 › 数据表日期字段值格式 › MySQL中日期时间类型与格式化 |
关联博文: MySQL中常用函数之日期函数使用详解 【1】MySQL中的日期时间类型MySQL中常用的几种时间类型有:date、datetime、time、year、timestamp 数据类型占用字节最小值最大值零值表示date41000-01-019999-12-310000-00-00datetime81000-01-01 00:00:009999-12-31 23:59:590000-00-00 00:00: 00timestamp4197001010800012038年的某个时刻0000000000000000time3-838:59:59838:59:5900:00:00year1190121550000 ① 详细解释datetime : 时间日期型,格式是YYYY-mm-dd HH:ii:ss,表示的范围是从1000到9999。但是有零值,0000-00-00 00:00:00; date:日期,就是datetime中的date部分; time:时间(段),指定的某个区间之间,从-时间到+时间(有负时间表示); timestamp:时间戳,并不是常规意义时间戳(如:14253685),范围是’1970-01-01 00:00:00’到2037年。格式为YYYY-mm-dd HH:ii:ss,格式与datetime完全一致; year:yy和yyyy,yyyy的范围是1901-2155,yy的范围是1970-2069。 两位year(00-69表示2000-2069,70-99表示1970~1999)。当应用只需要记录年份时,year比date更省空间 ② SQL语句实例 create table my_date( d1 datetime, d2 date, d3 time, d4 timestamp, d5 year )charset utf8; desc my_date如下图所示:year默认为4位,即YYYY; timestamp不能为空,有默认值,在创建新记录和修改现有记录的时候都对这个数据列刷新。
默认情况下只要当前所在的记录被更新,该字段一定会自动更新成当前时间。 update my_date set d1 = SYSDATE() where d5=69; select * from my_date那么MySQL可以拿到真正的时间戳吗?当然可以! select UNIX_TIMESTAMP();如下所示,通常我们MySQL中设计datetime类型长度都默认为0: `work_time` datetime(0) DEFAULT NULL COMMENT '清收时间',这时插入时间通常会是我们常见到的:2020-08-29 12:52:16格式。但是如果datetime(n)中的n不为0呢? `work_time` datetime(2) DEFAULT NULL COMMENT '清收时间', # datetime(n)中的n最大值为6 `work_time` datetime(6) DEFAULT NULL COMMENT '清收时间',这时在MySQL中会分别显示如下: 2020-08-29 12:52:16.01 2020-08-29 12:52:16.014057会发现最后有一个小数点且小数点后面会分别对应相应位数的数字–这称之为纳秒。 总结如下: date : 只有日期,没有时间; datetime : 有时间,有日期; time : 只有时间 ,精确到分秒 ; timestamp : 时间戳,精确到分秒; year : 年,如2002,如果写为 2002-01-15,将会进行计算,插入结果为1986 【2】日期时间类型格式化 ① DATE_FORMAT( )函数可以使用date_format( )函数进行时间的转换。 SELECT DATE_FORMAT(SYSDATE(),'%Y-%m-%d %H:%i:%s') from dual;字符串转换为date: str_to_date( '2016-12-15 16:48:40', '%Y-%m-%d %H:%i:%S' ) |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |