目次
カスタム データ型を使用して Gorm モデルに整数の配列を追加する
問題: 整数の配列を追加するときにパニックが発生する
解決策: 配列にカスタム データ型を使用する
整数配列を使用した挿入の例
ホームページ バックエンド開発 Golang PostgreSQL を使用して GORM モデルに整数の配列を保存するにはどうすればよいですか?

PostgreSQL を使用して GORM モデルに整数の配列を保存するにはどうすればよいですか?

Nov 05, 2024 am 01:20 AM

How to Store Arrays of Integers in a GORM Model Using PostgreSQL?

カスタム データ型を使用して Gorm モデルに整数の配列を追加する

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:&amp;quot;type:integer[]&amp;quot;`
        GameEndDate string    
}</code>
ログイン後にコピー

gorm タグでは、type:integer [] は、このフィールドがデータベース内で整数の配列として扱われることを指定します。

整数配列を使用した挿入の例

Gorm モデルに整数の配列を挿入するには、次を使用できます。次の構文:

<code class="go">dt := []int64{1, 2, 3}   
                                                                                
db.Create(&amp;amp;Game{GameCode: &amp;quot;xxx&amp;quot;, GameName: &amp;quot;xxx&amp;quot;, DeckType: pq.Int64Array(dt), GameEndDate: &amp;quot;xxx&amp;quot;})  </code>
ログイン後にコピー

以上がPostgreSQL を使用して GORM モデルに整数の配列を保存するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか? Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか? Mar 03, 2025 pm 05:17 PM

Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか?

GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか? GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか? Mar 10, 2025 pm 05:38 PM

GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか?

Beegoフレームワークのページ間で短期情報転送を実装する方法は? Beegoフレームワークのページ間で短期情報転送を実装する方法は? Mar 03, 2025 pm 05:22 PM

Beegoフレームワークのページ間で短期情報転送を実装する方法は?

GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか? GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか? Mar 10, 2025 pm 03:20 PM

GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか?

トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか? トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか? Mar 10, 2025 pm 05:36 PM

トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか?

Go言語でファイルを便利に書く方法は? Go言語でファイルを便利に書く方法は? Mar 03, 2025 pm 05:15 PM

Go言語でファイルを便利に書く方法は?

Linterと静的分析ツールを使用して、GOコードの品質と保守性を向上させるにはどうすればよいですか? Linterと静的分析ツールを使用して、GOコードの品質と保守性を向上させるにはどうすればよいですか? Mar 10, 2025 pm 05:38 PM

Linterと静的分析ツールを使用して、GOコードの品質と保守性を向上させるにはどうすればよいですか?

MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は? MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は? Mar 03, 2025 pm 05:18 PM

MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は?

See all articles