Wie speichere ich Arrays von Ganzzahlen in einem GORM-Modell mit PostgreSQL?

Linda Hamilton
Freigeben: 2024-11-05 01:20:02
Original
998 Leute haben es durchsucht

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

Hinzufü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>
Nach dem Login kopieren

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>
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage