我使用 sqlx 將 PostgreSQL boolan[] 選取到 Golang 結構中,其中目標結構值為 []*bool。
type App struct { ApplicationID string `db:"application_id"` Name string `db:"name"` Description string `db:"description"` Replicated []*bool `db:"replicated"` } var apps []App err := trx.Select(&apps, "Select * From my_function()")
傳回的錯誤是:sql: 欄位索引3 上掃描錯誤,名稱「replicated」: 不支援掃描,將driver.Value 類型[]uint8 儲存為型別*[]*bool
#我已經四處尋找,但還沒有找到解決方案。任何幫助將不勝感激!
您只能掃描實作 .Scanner
介面的內容。您可以將結構定義為
import "github.com/lib/pq" type App struct { ApplicationID string `db:"application_id"` Name string `db:"name"` Description string `db:"description"` Replicated pq.BoolArray `db:"replicated"` }
其中pq.BoolArray
是[]bool
,或者如果您確實需要它是[]*bool
,您可以建立自己的類型
type BoolArray []*bool
然後從此處複製程式碼https://github。 com/lib/pq/blob/2a217b94f5ccd3de31aec4152a541b9ff64bed05/array.go#L76 並根據需要進行修改
以上是列索引 8 上的掃描錯誤,名稱「replicated」:不支援掃描,將 driver.Value 類型 uint8 儲存為 **bool 類型的詳細內容。更多資訊請關注PHP中文網其他相關文章!