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

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

如何將間隔參數傳遞給預準備語句?

如何將間隔參數傳遞給預準備語句?

Go
收到一只叮咚 2022-09-19 21:22:53
我想刪除 Postgres 數據庫中早于 X 分鐘的所有數據庫條目。我在go中準備好的聲明看起來像這樣:deletefrom my_tablewhere expires < (to_timestamp($1) - '$2 minutes'::interval);如何正確傳遞第二個參數?$2PS:我知道有不同的語句可以解決這個問題,但我對如何傳遞引用的參數非常感興趣。
查看完整描述

4 回答

?
鳳凰求蠱

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

無法將參數內插到字符串文本中。

對于您的情況,一個可能的解決方案是將一個帶有間隔的數字相乘:

where expires < (to_timestamp($1) - $2 * '1 minute'::interval)


查看完整回答
反對 回復 2022-09-19
?
婷婷同學_

TA貢獻1844條經驗 獲得超8個贊

可以將參數強制轉換為 字符串 ,然后將其與字符串 連接text' minutes'

delete from my_table

where expires < (to_timestamp($1) - ($2::text || ' minutes')::interval

UPDATE:實際上,由于postgres確實有一個運算符,其結果是 ,你不應該需要類型轉換參數。any || texttext




查看完整回答
反對 回復 2022-09-19
?
慕的地8271018

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

您可以使用make_interval


delete from my_table

where expires < (to_timestamp($1) - make_interval(mins => $2));


查看完整回答
反對 回復 2022-09-19
?
慕村225694

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

您還可以改為參數化整個間隔字符串。這消除了對中間鑄造和連接的需求。text


query := `

  delete from my_table

  where expires < (to_timestamp($1) - $2::interval);

`

interval := fmt.Sprintf("%d minutes", mins)

db.Exec(query, timestamp, interval)


查看完整回答
反對 回復 2022-09-19
  • 4 回答
  • 0 關注
  • 100 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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