首頁 > 後端開發 > Golang > 列索引 8 上的掃描錯誤,名稱「replicated」:不支援掃描,將 driver.Value 類型 uint8 儲存為 **bool 類型

列索引 8 上的掃描錯誤,名稱「replicated」:不支援掃描,將 driver.Value 類型 uint8 儲存為 **bool 類型

PHPz
發布: 2024-02-12 15:15:07
轉載
925 人瀏覽過

列索引 8 上的扫描错误,名称“replicated”:不支持扫描,将 driver.Value 类型 uint8 存储为 **bool 类型

問題內容

我使用 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中文網其他相關文章!

來源:stackoverflow.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板