5

我正在尝试将时间戳加载到 mysql 中。我所有的时间都是 UTCTime 对象。HDBC mysql 实现似乎不喜欢 UTCTime 对象,尽管内部文档说它将所有时间都视为 UTC 时间。我相信我需要将 UTCTime 转换为 EpochTime,因为它看起来像 HDBC mysql 实现支持绑定 SqlEpochTime。我无法弄清楚如何获取我的 UTCTime 并从中获取 EpochTime。

4

1 回答 1

4

现在有一个解决方法:

import Data.Time.Clock (UTCTime)
import Data.Time.Clock.POSIX (utcTimeToPOSIXSeconds)
import Database.HDBC (SqlValue (SqlEpochTime))

-- until HDBC-mysql fixes it. use instead of SqlUTCTime (data constructor)
sqlUTCTime :: UTCTime -> SqlValue
sqlUTCTime = SqlEpochTime . floor . utcTimeToPOSIXSeconds

我在 3 周前向 Chris Waterson(HDBC-mysql 的维护者)发送了一个修复程序,他说他会将其合并到下一个版本中。

于 2010-07-12T17:39:38.547 回答