GORM Go を使用したカスタム セット データ型の永続化
提供されたコードは、カスタム セット データ型 threadUnsafeSet とそれに付随するメソッドを定義します。 MySQL の GORM ライブラリを使用してこのデータ型を永続化するには、Scanner および Driver Valuer インターフェイスの実装が必要です。
Scanner および Driver Valuer インターフェイスの実装
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 中国語 Web サイトの他の関連記事を参照してください。