


Wie speichere ich Arrays von Ganzzahlen in einem GORM-Modell mit PostgreSQL?
Nov 05, 2024 am 01:20 AMHinzufügen eines Arrays von Ganzzahlen zu einem Gorm-Modell mithilfe eines benutzerdefinierten Datentyps
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.
Problem: Panik beim Hinzufügen eines Arrays von Ganzzahlen
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.
Lösung: Verwendung eines benutzerdefinierten Datentyps für Arrays
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:&quot;type:integer[]&quot;` 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.
Beispiel für das Einfügen mit einem Ganzzahl-Array
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(&amp;Game{GameCode: &quot;xxx&quot;, GameName: &quot;xxx&quot;, DeckType: pq.Int64Array(dt), GameEndDate: &quot;xxx&quot;}) </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!

Heißer Artikel

Hot-Tools-Tags

Heißer Artikel

Heiße Artikel -Tags

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

GO Language Pack Import: Was ist der Unterschied zwischen Unterstrich und ohne Unterstrich?

Wie schreibe ich Scheinobjekte und Stubs zum Testen in Go?

Wie kann ich kurzfristige Informationsübertragung zwischen Seiten im BeEGO-Framework implementieren?

Wie kann ich benutzerdefinierte Typ -Einschränkungen für Generika in Go definieren?

Wie kann ich Tracing -Tools verwenden, um den Ausführungsfluss meiner GO -Anwendungen zu verstehen?

Wie schreibe ich Dateien in Go Language bequem?

Wie kann ich Linter und statische Analyse -Tools verwenden, um die Qualität und Wartbarkeit meines GO -Codes zu verbessern?

Wie konvertieren Sie die Liste der MySQL -Abfrageergebnisse in eine benutzerdefinierte Struktur -Slice in Go -Sprache?
