如何解决为什么用CAST添加TIME不适用于MySQL中的每一行?
我正在使用此查询SELECT *,cast(seg1 + seg2 as time) FROM tablename
,但只添加了最后两行,为什么?
每个seg *列均为TIME
类型。
最后两行是在phpMyAdmin中手动添加的,其他两行是通过Yii框架ActiveQuery添加的。
这是PhpMyAdmin的结果:
解决方法
当您对两个time
值求和时,MYSQL中发生奇怪的事情。即,MySQL将两个值都转换为数字(只需删除':'
字符),然后对其求和。考虑以下示例:
select cast('12:43:34' as time) + cast('04:09:32' as time) res
| res | | -----: | | 165266 |
结果为124334 + 40932
。
一种执行所需操作的方法是将时间转换为秒,将其相加,然后将结果转换为时间:
select t.*,sec_to_time(time_to_sec(seg1) + time_to_sec(seg2)) total_time
from tablename t
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。