In der Programmiersprache Go ist GORM ein beliebtes ORM-Framework (Object-Relational Mapper). für die Arbeit mit Datenbanken. Bei der Arbeit mit einer relationalen Datenbank wie PostgreSQL ist es häufig erforderlich, Wertesammlungen in einem einzelnen Feld, einem sogenannten Array, zu speichern.
Beim Versuch Um ein Array von Ganzzahlen []int64 zu einem Gorm-Modellfeld hinzuzufügen, könnte der Fehler auftreten: „Panik: Ungültiger SQL-Typ (Slice) für Postgres.“ Dieser Fehler tritt auf, weil Gorm einen Slice nicht automatisch einem Datenbankfeld zuordnen kann.
Um dieses Problem zu beheben, ist es notwendig, einen bereitgestellten benutzerdefinierten Datentyp zu verwenden durch die zugrunde liegende Datenbankbibliothek. Im Fall von PostgreSQL bietet die pq-Bibliothek eine Möglichkeit, ein Integer-Array als benutzerdefinierten Typ pq.Int64Array für das DeckType-Feld im Gorm-Modell darzustellen:
<code class="go">type Game struct { gorm.Model GameCode string GameName string DeckType pq.Int64Array `gorm:"type:integer[]"` GameEndDate string }</code>
Geben Sie im Gorm-Tag Folgendes ein:integer [] gibt an, dass dieses Feld als Array von Ganzzahlen in der Datenbank behandelt werden soll.
Um ein Array von Ganzzahlen in ein Gorm-Modell einzufügen, kann man verwenden die folgende Syntax:
<code class="go">dt := []int64{1, 2, 3} db.Create(&Game{GameCode: "xxx", GameName: "xxx", DeckType: pq.Int64Array(dt), GameEndDate: "xxx"}) </code>
Das obige ist der detaillierte Inhalt vonWie speichere ich Arrays von Ganzzahlen in einem GORM-Modell mit PostgreSQL?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!