【问题标题】:How to calculate time ? in postgresql example 08:00:00 - 07:30:00 = 0.3hour?如何计算时间?在 postgresql 示例中 08:00:00 - 07:30:00 = 0.3 小时?
【发布时间】:2021-05-31 21:05:02
【问题描述】:

enter image description here

SELECT time_in,time_out
FROM appointment_trainer;

我想计算它,例如 08:00:00 - 07:30:00 = 0.3 小时?可以在 postgresql 中使用吗?

【问题讨论】:

  • 8:00 和 7:30 之间的差异不是 0.3h 而是 0.5。你想要 0h 30min 还是 0.5h?

标签: postgresql time timestamp


【解决方案1】:

减去它们:

select time_out - time_in
FROM appointment_trainer;

这将返回一个interval,它是 SQL 中表示“持续时间”的数据类型

【讨论】:

  • 我的问题已经解决了,谢谢先生
【解决方案2】:

demos:db<>fiddle

如果你想获得像00:30:00 这样的时间,那么你可以这样做:

SELECT time_out - time_in
FROM appointment_trainer

这将返回一个类型interval。如果你想得到一个类型time,你可以在之后转换它:

SELECT (time_out - time_in)::time
FROM appointment_trainer

如果你想得到0.5小时,你可以使用EXTRACT(EPOCH FROM ...),它返回interval的秒数,当然可以计算成小时:

SELECT extract(epoch from time_out - time_in) / 60 / 60
FROM appointment_trainer

【讨论】:

  • 不客气。感谢您的接受,如果您也可以 UPVOTE ,我将不胜感激 :)
猜你喜欢
  • 1970-01-01
  • 2015-04-12
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2022-07-28
相关资源
最近更新 更多