Go プログラミング言語では、GORM は人気のある ORM (オブジェクト リレーショナル マッパー) フレームワークですデータベースを操作するためのものです。 PostgreSQL などのリレーショナル データベースを使用する場合、多くの場合、値のコレクションを配列と呼ばれる 1 つのフィールドに保存する必要があります。
整数の配列 []int64 を Gorm モデル フィールドに追加すると、「パニック: postgres の SQL タイプ (スライス) が無効です。」というエラーが発生する可能性があります。このエラーは、Gorm がスライスをデータベース フィールドに自動的にマップできないために発生します。
この問題を解決するには、提供されているカスタム データ型を使用する必要があります。基礎となるデータベース ライブラリによって。 PostgreSQL の場合、pq ライブラリは、Gorm モデルの DeckType フィールドのカスタム型 pq.Int64Array として整数配列を表す方法を提供します。
<code class="go">type Game struct { gorm.Model GameCode string GameName string DeckType pq.Int64Array `gorm:"type:integer[]"` GameEndDate string }</code>
gorm タグでは、type:integer [] は、このフィールドがデータベース内で整数の配列として扱われることを指定します。
Gorm モデルに整数の配列を挿入するには、次を使用できます。次の構文:
<code class="go">dt := []int64{1, 2, 3} db.Create(&Game{GameCode: "xxx", GameName: "xxx", DeckType: pq.Int64Array(dt), GameEndDate: "xxx"}) </code>
以上がPostgreSQL を使用して GORM モデルに整数の配列を保存するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。