亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

golang 比較時間大小

golang 比較時間大小

Go
慕桂英3389331 2022-07-11 16:51:25
我想在當前時間和數據庫數據之間進行比較。我的代碼是:var PayBlockedLog[] model.PayBlockedLog    global.DB.Where("status = ?",0).Find(&PayBlockedLog)    for i := 0; i <len(PayBlockedLog); i++ {        if time.Now().Unix() < PayBlockedLog[i].UnsealTime{        }    }看來我應該將 PayBlockedLog[i].UnsealTime 轉換為 int64。試過后沒有效果
查看完整描述

1 回答

?
九州編程

TA貢獻1785條經驗 獲得超4個贊

而不是獲取然后過濾,而是在查詢中進行過濾。這將節省時間和內存,并避免時區問題。

我不知道您使用的是什么數據庫,也不知道UnsealTime. 如果是timestampor datetime(應該是),請對照current_timestamp.

global
  .DB
  .Where("status = ? and current_timestamp < UnsealTime", 0)
  .Find(&PayBlockedLog)

如果距 Unix 紀元還有幾秒鐘,請考慮將其轉換為普通timestamp列,以便可以使用日期/時間函數。有幾種方法可以實現這一點,同時保持舊列的兼容性。

否則,您可以將當前時間轉換為紀元秒。如何執行此操作取決于數據庫。這是在 Postgres 中。

global
  .DB
  .Where("status = ? and extract(epoch from current_timestamp) < UnsealTime", 0)
  .Find(&PayBlockedLog)


查看完整回答
反對 回復 2022-07-11
  • 1 回答
  • 0 關注
  • 122 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號