Inhaltsverzeichnis
Hinzufügen eines Arrays von Ganzzahlen zu einem Gorm-Modell mithilfe eines benutzerdefinierten Datentyps
Problem: Panik beim Hinzufügen eines Arrays von Ganzzahlen
Lösung: Verwendung eines benutzerdefinierten Datentyps für Arrays
Beispiel für das Einfügen mit einem Ganzzahl-Array
Heim Backend-Entwicklung Golang Wie speichere ich Arrays von Ganzzahlen in einem GORM-Modell mit PostgreSQL?

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

Nov 05, 2024 am 01:20 AM

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:&amp;quot;type:integer[]&amp;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;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>
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!

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

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

GO Language Pack Import: Was ist der Unterschied zwischen Unterstrich und ohne Unterstrich? GO Language Pack Import: Was ist der Unterschied zwischen Unterstrich und ohne Unterstrich? Mar 03, 2025 pm 05:17 PM

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

Wie schreibe ich Scheinobjekte und Stubs zum Testen in Go? Wie schreibe ich Scheinobjekte und Stubs zum Testen in Go? Mar 10, 2025 pm 05:38 PM

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 kurzfristige Informationsübertragung zwischen Seiten im BeEGO-Framework implementieren? Mar 03, 2025 pm 05:22 PM

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 benutzerdefinierte Typ -Einschränkungen für Generika in Go definieren? Mar 10, 2025 pm 03:20 PM

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 kann ich Tracing -Tools verwenden, um den Ausführungsfluss meiner GO -Anwendungen zu verstehen? Mar 10, 2025 pm 05:36 PM

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

Wie schreibe ich Dateien in Go Language bequem? Wie schreibe ich Dateien in Go Language bequem? Mar 03, 2025 pm 05:15 PM

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 kann ich Linter und statische Analyse -Tools verwenden, um die Qualität und Wartbarkeit meines GO -Codes zu verbessern? Mar 10, 2025 pm 05:38 PM

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? Wie konvertieren Sie die Liste der MySQL -Abfrageergebnisse in eine benutzerdefinierte Struktur -Slice in Go -Sprache? Mar 03, 2025 pm 05:18 PM

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

See all articles