首頁 > 後端開發 > Golang > 主體

如何使用 GORM 和 MySQL 儲存自訂 Go Set 資料類型?

Susan Sarandon
發布: 2024-11-19 20:27:03
原創
374 人瀏覽過

How to Persist a Custom Go Set Data Type with GORM and MySQL?

使用 GORM Go 保留自訂集資料類型

提供的程式碼定義了自訂集資料型別 threadUnsafeSet 及其隨附方法。若要使用 MySQL 的 GORM 程式庫保留此資料類型,需要實作掃描器和驅動程式值器介面。

掃描器和驅動器值器介面實作

Scanner介面用於將資料庫值掃描為Go值,而Driver Valuer介面則用於將Go值轉換為資料庫驅動值。對於 threadUnsafeSet 類型,這表示實作將自訂集轉換為資料庫相容格式的方法,反之亦然。

範例實作可能如下所示:

func (data *threadUnsafeSet) Value() (driver.Value, error) {
    return data.ConvertJSONToString(), nil
}

func (data *threadUnsafeSet) Scan(value interface{}) error {
    *data = data.ConvertStringToJson(valueString)
}
登入後複製

在此範例中,ConvertJSONToString 和ConvertStringToJson 方法將自訂集與JSON 字串相互轉換,然後可以將其儲存在資料庫中。

透過實作這些接口,GORM 現在可以了解如何儲存和擷取threadUnsafeSet 類型

注意: 您應該將虛擬的ConvertJSONToString 和ConvertStringToJson 方法呼叫為符合您的方法呼叫特定資料類型轉換要求的實際實作。

以上是如何使用 GORM 和 MySQL 儲存自訂 Go Set 資料類型?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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