第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

使用 GORM golang 持久化自定義集數(shù)據(jù)類型

使用 GORM golang 持久化自定義集數(shù)據(jù)類型

Go
皈依舞 2022-05-23 17:49:48
我Set在 go 中創(chuàng)建了一個自定義數(shù)據(jù)類型,我用它來定義一對多關(guān)系。例如在我的架構(gòu)中,我有以下結(jié)構(gòu)定義type Doctor struct {  firstName string  lastName string  capabilities commons.Set }這capabilities是一組具有以下值的字符串chat, audio, video,通過此設(shè)置,我試圖將上述結(jié)構(gòu)保留到MySQL使用GORM庫中,但是當我這樣做時,出現(xiàn)以下錯誤panic: invalid sql type Set (interface) for mysqlgoroutine 6 [running]:catalog/vendor/github.com/jinzhu/gorm.(*mysql).DataTypeOf(0xc00027e8a0, 0xc00024d680, 0x8, 0x8)    /home/kumard/go/src/catalog/vendor/github.com/jinzhu/gorm/dialect_mysql.go:123 +0xce9catalog/vendor/github.com/jinzhu/gorm.(*Scope).createTable(0xc000169400, 0xc14e60)我知道我必須實現(xiàn)某些方法才能實現(xiàn)這一點,但我無法確定要在此處實現(xiàn)哪個方法/回調(diào)。
查看完整描述

1 回答

?
慕姐4208626

TA貢獻1852條經(jīng)驗 獲得超7個贊

您需要為自定義類型實現(xiàn)Scanner & Driver Valuer接口,然后數(shù)據(jù)庫驅(qū)動程序才能知道如何將數(shù)據(jù)存儲在數(shù)據(jù)庫中以及如何從數(shù)據(jù)庫中獲取數(shù)據(jù)。


func (data *CustomType) Value() (driver.Value, error) {

    ...

}

func (data *CustomType) Scan(value interface{}) error {

    ...

}

示例:假設(shè) UserAccess 是map[interface{}]struct{}類型。


type UserAccess map[interface{}]struct{}


func (data *UserAccess) Value() (driver.Value, error) {

    return data.ConvertJSONToString(), nil

}

func (data *UserAccess) Scan(value interface{}) error {

    *data = data.ConvertStringToJson(valueString)

}

這里用于將自定義數(shù)據(jù)類型值轉(zhuǎn)換為數(shù)據(jù)庫兼容類型,如 json-string ConvertStringToJson。ConvertJSONToString


查看完整回答
反對 回復 2022-05-23
  • 1 回答
  • 0 關(guān)注
  • 210 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號