使用Slice IN 子句進行Golang 資料庫查詢:了解挑戰
嘗試在Golang 中使用帶有整數切片的IN 子句時資料庫查詢時,您可能會遇到意外的行為。讓我們探討一下背後的原因並找出慣用的解決方案。
標準的database/sql 套件不會自動處理有切片的IN 子句。相反,它將查詢直接轉換為資料庫,其中綁定變數 (?) 代表單一參數。當嘗試根據切片的長度包含可變數量的參數時,這可能會導致混亂。
例如,以下查詢將失敗:
var levels = []int{4, 6, 7} rows, err := db.Query("SELECT * FROM users WHERE level IN (?);", levels)
要克服此限制,您可以利用 sqlx 包,它可以更好地控制資料庫查詢。透過使用sqlx.In 預處理查詢,您可以將切片指定為參數:
var levels = []int{4, 6, 7} query, args, err := sqlx.In("SELECT * FROM users WHERE level IN (?);", levels)
現在,查詢已修改為包含與切片長度相對應的多個綁定變量,並且您可以成功執行。
要更深入地了解如何使用 sqlx.In,請參閱其位於 Godoc 的文檔。這種方法提供了一種更慣用且靈活的方式來處理 Golang 資料庫查詢中帶有切片的 IN 子句。
以上是如何在 Golang 資料庫查詢中處理帶有切片的'IN”子句:避免陷阱?的詳細內容。更多資訊請關注PHP中文網其他相關文章!