mysql中将时间转为秒

本文介绍了如何在数据库查询中将时间(时分秒)转换为秒的方法,利用TIME_TO_SEC函数实现时分秒到秒的转换,并提供了秒转换回时分秒的函数SEC_TO_TIME。此外,还介绍了如何使用UNIX_TIMESTAMP函数来计算包含日期的时间戳差值。

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

项目中遇到的问题,需要将时间(时 分 秒)转为秒,业务上处理有些麻烦,尝试找了多种处理函数,然而并没有用

完美解决办法:

TIME_TO_SEC   格式'HH:MM:SS'或HHMMSS

SELECT
userId,marks, ifnull(TIME_TO_SEC(usedTime),'0') usedTimes,usedTime
FROM
x_courseissued x
where
x.isflag= 'B' AND x.flag= 0
AND (x.stateFlag='Y' or x.stateFlag='P')

并且这个函数可以相互转换:秒  转    时 分 秒 

SELECT SEC_TO_TIME(120);

 

 

但是TIME_TO_SEC 是把 时分秒转为 秒,并不会对年月日进行处理;

如果业务有需要可以使用UNIX_TIMESTAMP

 UNIX_TIMESTAMP 函数返回的是自1970年以来的秒数,所以时间计算业务需要的话可以使用这个函数

应用场景计算两个时间差开始时间  结束时间

SELECT (UNIX_TIMESTAMP(STR_TO_DATE(end_time,'%Y-%m-%d %H:%i:%s')) -
UNIX_TIMESTAMP(STR_TO_DATE(begin_time,'%Y-%m-%d %H:%i:%s'))) useTime

SELECT (UNIX_TIMESTAMP(STR_TO_DATE('2017-10-1 00:05:00','%Y-%m-%d %H:%i:%s')) -
UNIX_TIMESTAMP(STR_TO_DATE('2017-10-1 00:00:00','%Y-%m-%d %H:%i:%s'))) useTime

 

  

 

转载于:https://www.cnblogs.com/chenliangcl/p/7654878.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值