問題:
為什麼下面的Golang 資料庫查詢在IN 子句中使用整數切片失敗:
答案:
出現此問題的原因是用於查詢的資料庫/sql 套件未檢查查詢並將參數直接傳遞給資料庫驅動程式。這使得處理包含可變數量參數的 IN 子句的查詢具有挑戰性。
在提供的查詢中,?綁定變數對應於單一參數,而預期用途是根據切片 artIds 的長度綁定多個參數。但是,驅動程式無法正確處理此問題。
要解決此問題,建議使用 sqlx 包,它可以更好地控制資料庫查詢。
解決方案使用sqlx 套件:
sqlx.In 函數處理查詢並為整數切片產生適當的綁定變量,使查詢能夠成功執行。
有關此主題的更多信息,請參閱 InQueries 的 Godoc 文件。
以上是如何在 IN 子句中使用切片執行 Go 資料庫查詢?的詳細內容。更多資訊請關注PHP中文網其他相關文章!