首頁 >後端開發 >Golang >如何使用 SQLx 透過 ID 切片查詢 MySQL?

如何使用 SQLx 透過 ID 切片查詢 MySQL?

DDD
DDD原創
2024-12-05 12:34:10929瀏覽

How to Query MySQL with a Slice of IDs Using SQLx?

使用SQLx 查詢MySQL 取得切片中的值

在MySQL 表中查詢切片中包含的值時,使用者可能會遇到類似下列錯誤:

sql: converting Exec argument #0's type: unsupported type []int, a slice

出現此問題是因為SQLx 本身不支援使用切片作為參數來查詢。不過,它透過 In() 函數提供了解決方案。

使用 In() 的解決方案

要解決此錯誤,可以採取以下步驟:

  1. 使用 In()準備查詢以將切片包含為參數:

    query, args, err := sqlx.In("SELECT * FROM quote WHERE qid IN (?)", qids)
    if err != nil {
     log.Fatal(err)
    }
  2. 重新綁定查詢以使其與資料庫後端相容:

    query = database.SQL.Rebind(query)
  3. 使用Select(執行查詢):

    err = database.SQL.Select(&quotes, query, args...)

組合一行

整個過程可以簡化為一行:

err = database.SQL.Select(&quotes, database.SQL.Rebind(query), args...)

資源

更多範例和文檔,請參考SQLx 官方網站: http://jmoiron.github.io/sqlx/

以上是如何使用 SQLx 透過 ID 切片查詢 MySQL?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn