mysql 日期 字符串 时间戳转换

本文介绍MySQL中日期与时间的各种转换方法,包括日期到字符串、时间到时间戳、字符串到时间等,并提供了具体示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mysql 日期 字符串 时间戳转换

复制代码
 1 #时间转字符串
 2 select date_format(now(), '%Y-%m-%d');  
 3 #结果:2017-02-27
 4 
 5 #时间转时间戳
 6 select unix_timestamp(now()); 
 7 #结果:1488160428
 8 
 9 #字符串转时间
10 select str_to_date('2017-02-27', '%Y-%m-%d %H');  
11 #结果:2017-02-27 00:00:00
12 
13 #字符串转时间戳
14 select unix_timestamp('2017-02-27');  
15 #结果:1488124800
16 
17 #时间戳转时间
18 select from_unixtime(1488160428);  
19 #结果:2017-02-27 09:53:48
20 
21 #时间戳转字符串
22 select from_unixtime(1488160428,'%Y-%m-%d %T');  
23 #结果:2017-02-27 09:53:48
复制代码

MySQL日期格式化(format)取值范围。

 含义
%S、%s两位数字形式的秒( 00,01, ..., 59)
%I、%i两位数字形式的分( 00,01, ..., 59)
小时 %H24小时制,两位数形式小时(00,01, ...,23)
%h12小时制,两位数形式小时(00,01, ...,12)
%k24小时制,数形式小时(0,1, ...,23)
%l12小时制,数形式小时(0,1, ...,12)
%T24小时制,时间形式(HH:mm:ss)
%r 12小时制,时间形式(hh:mm:ss AM 或 PM)
%p AM上午或PM下午 
  周  %W一周中每一天的名称(Sunday,Monday, ...,Saturday)
 %a一周中每一天名称的缩写(Sun,Mon, ...,Sat) 
%w 以数字形式标识周(0=Sunday,1=Monday, ...,6=Saturday) 
%U数字表示周数,星期天为周中第一天
%u数字表示周数,星期一为周中第一天
%d 两位数字表示月中天数(01,02, ...,31)
%e  数字表示月中天数(1,2, ...,31)
 %D英文后缀表示月中天数(1st,2nd,3rd ...) 
 %j以三位数字表示年中天数(001,002, ...,366) 
%M 英文月名(January,February, ...,December) 
%b 英文缩写月名(Jan,Feb, ...,Dec) 
%m 两位数字表示月份(01,02, ...,12)
%c 数字表示月份(1,2, ...,12) 
%Y 四位数字表示的年份(2015,2016...)
%y  两位数字表示的年份(15,16...)
文字输出 %文字 直接输出文字内容
### 如何在 MySQL 中将字符串转换时间戳 在处理数据时,有时会遇到需要将字符串类型的日期时间信息转换成 `TIMESTAMP` 类型的情况。MySQL 提供了几种方式来实现这一目标。 #### 使用 STR_TO_DATE 函数 对于特定格式的字符串可以使用 `STR_TO_DATE()` 函数将其解析并化为 `DATETIME` 或者 `TIMESTAMP` 类型的数据。此函数接受两个参数:一个是待化的时间表示形式作为字符串;另一个是指定该字符串所遵循的具体格式模式串[^1]。 例如: ```sql SELECT STR_TO_DATE('2021-1-1 00:00:00', '%Y-%m-%d %H:%i:%s') AS converted_timestamp; ``` 这段 SQL 将返回一个具有正确格式化的 `TIMESTAMP` 值。 #### 利用 UNIX_TIMESTAMP 和 FROM_UNIXTIME 组合 如果输入的是 Unix 时间戳(即自纪元以来经过了多少秒),可以直接利用这两个内置函数来进行相互之间的变换。不过这里讨论的是从常规字符表达到标准时间戳,则只需关注后者即可[^2]。 比如下面的例子展示了如何把形如 `'YYYY-MM-DD HH:MM:SS'` 的字符串通过中间件变成真正的 `TIMESTAMP` 对象: ```sql SELECT FROM_UNIXTIME(UNIX_TIMESTAMP('2021-1-1 00:00:00')) AS unix_to_timestamp; ``` 需要注意的是,在实际应用过程中应当确保源字符串确实代表了一个合法有效的日期/时刻描述,并且其内部结构要严格匹配所提供的模板样式,否则可能会引发异常错误或者得到意想不到的结果。 另外值得注意的一点是在某些情况下可能还会碰到由于区域设置差异而导致的不同月份缩写的识别问题,因此建议尽可能采用完整的年月日小时分钟秒钟的形式书写日期时间字符串以减少不必要的麻烦[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值