recherche
Maisondéveloppement back-endGolangComment stocker un tableau d'entiers dans un modèle Gorm à l'aide de PostgreSQL ?

How to Store an Array of Integers in a Gorm Model Using PostgreSQL?

Ajout d'un tableau d'entiers comme type de données dans un modèle Gorm

Introduction :
Quand vous travaillez avec PostgreSQL utilisant Gorm, l'ajout d'un tableau d'entiers comme type de données dans un modèle peut présenter des défis. Cet article aborde un problème courant rencontré lors de la tentative d'une telle opération.

Problème :
Les modèles Gorm rencontrent souvent une erreur lorsqu'ils tentent d'enregistrer un tableau de nombres dans un seul champ PostgreSQL. L'erreur se lit généralement comme suit : "panique : type SQL (slice) invalide pour postgres."

Dépannage :
Le problème provient de l'utilisation de la tranche comme type de données. La solution consiste à utiliser des types personnalisés de la bibliothèque de pilotes PostgreSQL sous-jacente.

Solution :
Dans le modèle fourni :

<code class="go">type Game struct {
    gorm.Model
    GameCode    string
    GameName    string
    DeckType    pq.Int64Array
    GameEndDate string
}</code>

Remplacez DeckType []int64 par DeckType pq.Int64Array, où pq est importé en tant qu'import pq "github.com/lib/pq".

Balise GORM :
Pour mapper correctement le type personnalisé à la colonne de la base de données , ajoutez une balise gorm pour spécifier le type de colonne :

<code class="go">DeckType    pq.Int64Array `gorm:"type:integer[]"`</code>

Cette balise indique que le champ DeckType doit être mappé à un tableau d'entiers PostgreSQL.

Exemple d'insertion :
Après avoir modifié le modèle et ajouté la balise GORM, vous pouvez insérer un tableau d'entiers dans la base de données :

<code class="go">dt := []int64{1, 2, 3}

db.Create(&Game{GameCode: "xxx", GameName: "xxx", DeckType: pq.Int64Array(dt), GameEndDate: "xxx"})</code>

En utilisant le type personnalisé et la balise GORM, vous pouvez enregistrer avec succès un tableau de entiers dans un champ PostgreSQL.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Erreurs de journalisation efficacement dans les applications GOErreurs de journalisation efficacement dans les applications GOApr 30, 2025 am 12:23 AM

La journalisation d'erreur d'application GO efficace nécessite d'équilibrer les détails et les performances. 1) L'utilisation de packages de journaux standard est simple mais manque de contexte. 2) Logrus fournit des journaux structurés et des champs personnalisés. 3) ZAP combine les performances et les journaux structurés, mais nécessite plus de paramètres. Un système de journalisation d'erreur complet doit inclure l'enrichissement des erreurs, le niveau de journal, la journalisation centralisée, les considérations de performances et les modes de gestion des erreurs.

Interfaces vides (interface {}) dans Go: cas d'utilisation et considérationsInterfaces vides (interface {}) dans Go: cas d'utilisation et considérationsApr 30, 2025 am 12:23 AM

Vide InterfacesIngoAreInterfaces avec des étages, représentant l'analyse de la valeur et devait être informé de la maintenance

Comparaison des modèles de concurrence: allez par rapport aux autres languesComparaison des modèles de concurrence: allez par rapport aux autres languesApr 30, 2025 am 12:20 AM

Go'sconcurrencyModeLelisunieDuetOtsUseofgoroutinesandChannels, offrant auxquels l'offrand de poids et de la responsabilité approfondie axés

Modèle de concurrence de Go: Goroutines et canaux expliquésModèle de concurrence de Go: Goroutines et canaux expliquésApr 30, 2025 am 12:04 AM

Go'sconcurrencyModeLuSeSGoroutinesandChannelStomageConCurrentProgrammingation efficace.1)

Interfaces et polymorphisme en Go: réutiliser le codeInterfaces et polymorphisme en Go: réutiliser le codeApr 29, 2025 am 12:31 AM

Interfaces andPolymorphisMingoenhanceCodeRelevitality andmainaipability.1) Définir les interfaces de théâtre.

Quel est le rôle de la fonction 'init' dans GO?Quel est le rôle de la fonction 'init' dans GO?Apr 29, 2025 am 12:28 AM

TheinitfonctioningorunsautomAticalement pour que la façon dont la convention est en train

Composition d'interface dans Go: construire des abstractions complexesComposition d'interface dans Go: construire des abstractions complexesApr 29, 2025 am 12:24 AM

Les combinaisons d'interface créent des abstractions complexes dans la programmation GO en décomposant les fonctions en petites interfaces focalisées. 1) Définissez le lecteur, l'écrivain et les interfaces plus étroites. 2) Créez des types complexes tels que le fichier et le réseau de réseaux en combinant ces interfaces. 3) Utilisez la fonction ProcessData pour montrer comment gérer ces interfaces combinées. Cette approche améliore la flexibilité du code, la testabilité et la réutilisabilité, mais il faut prendre soin d'éviter une fragmentation excessive et une complexité combinatoire.

Pièges et considérations potentielles lors de l'utilisation des fonctions d'initiés dans GoPièges et considérations potentielles lors de l'utilisation des fonctions d'initiés dans GoApr 29, 2025 am 12:02 AM

InitisctionsingoaReAutomAticalement compte tenu de la fin de la manière

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Version Mac de WebStorm

Version Mac de WebStorm

Outils de développement JavaScript utiles

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

PhpStorm version Mac

PhpStorm version Mac

Le dernier (2018.2.1) outil de développement intégré PHP professionnel

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

Adaptateur de serveur SAP NetWeaver pour Eclipse

Adaptateur de serveur SAP NetWeaver pour Eclipse

Intégrez Eclipse au serveur d'applications SAP NetWeaver.