Table des matières
Contenu de la question
Solution de contournement
Maison développement back-end Golang La configuration de sqlc.yaml ne remplace pas l'intervalle postgresql par time.Duration

La configuration de sqlc.yaml ne remplace pas l'intervalle postgresql par time.Duration

Feb 09, 2024 pm 08:09 PM

sqlc.yaml 配置不会覆盖 postgresql 时间间隔到 time.Duration

L'éditeur PHP Youzi est là pour vous présenter une question sur la configuration de sqlc.yaml. Lors de l'utilisation de postgresql, nous devons souvent utiliser un intervalle de temps (time.Duration) pour représenter une période de temps. Cependant, nous constatons parfois que la configuration de l'intervalle de temps dans le fichier de configuration sqlc.yaml ne prend pas effet, mais est remplacée par la configuration par défaut. Comment résoudre ce problème? Veuillez continuer à lire cet article et nous vous donnerons des réponses détaillées.

Contenu de la question

J'ai trouvé un problème avec l'application sqlc codegen. Juste au cas où, quand j'en aurais besoin interval (postgresql) 字段时,sqlc 会生成一个带有 int64 字段的对象。此解决方案看起来已损坏,并在扫描行时产生错误: errorf("cannot conversion %v to interval", value)

sqlc.yaml :

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

version: "2"

overrides:

  go:

    overrides:

      - db_type: "interval"

        engine: "postgresql"

        go_type:

          import: "time"

          package: "time"

          type: "https://pkg.go.dev/time#duration"

sql:

  - queries: "./sql_queries/raffle.query.sql"

    schema: "./migrations/001-init.sql"

    engine: "postgresql"

    gen:

     go:

        package: "raffle_repo"

        out: "../repo/sql/raffle_repo"

        sql_package: "pgx/v4"

Copier après la connexion

schema.sql :

1

2

3

4

5

6

7

8

9

10

11

12

create table windowrange

(

    id        serial    primary key,

    open      timestamp not null ,

    duration  interval not null,

    created_at timestamp default now(),

    updated_at timestamp default now(),

    raffle_id integer not null

        constraint raffle_id

            references raffle

            on delete cascade

);

Copier après la connexion

Modèle généré :

1

2

3

4

5

6

7

8

type Windowrange struct {

    ID        int32

    Open      time.Time

    Duration  int64

    CreatedAt sql.NullTime

    UpdatedAt sql.NullTime

    RaffleID  int32

}

Copier après la connexion

Le problème a été rapidement résolu en définissant ce champ sur type time.duration. durée et le code commence à fonctionner, mais ce code est généré et ressemble à une mauvaise décision.

Lorsque j'essaie de remplacer le type via la configuration sqlc.yaml, je n'obtiens rien, l'objet est toujours en cours de création de type int64. Où ai-je commis une erreur et comment puis-je résoudre ce problème ?

Solution de contournement

Sous Types pris en charge , vous verrez pg_catalog.interval 也是 postgres 中 interval l'une des valeurs prises en charge.

Donc, si vous souhaitez simplement utiliser la partie time.duration 而不是 int64,则需要将 overrides, changez pour :

1

2

3

4

5

6

7

8

overrides:

  go:

    overrides:

      - db_type: "pg_catalog.interval"

        engine: "postgresql"

        go_type:

          import: "time"

          type: "Duration"

Copier après la connexion

Conseil : Si cela ne fonctionne pas pour le type de données le plus évident, vous pouvez en essayer un autre.

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 de ce site Web
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

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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
4 Il y a quelques semaines By DDD
Musée à deux points: toutes les expositions et où les trouver
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Comment utilisez-vous l'outil PPROF pour analyser les performances GO? Comment utilisez-vous l'outil PPROF pour analyser les performances GO? Mar 21, 2025 pm 06:37 PM

L'article explique comment utiliser l'outil PPROF pour analyser les performances GO, notamment l'activation du profilage, la collecte de données et l'identification des goulots d'étranglement communs comme le processeur et les problèmes de mémoire. COMMANDE: 159

Comment rédigez-vous des tests unitaires en Go? Comment rédigez-vous des tests unitaires en Go? Mar 21, 2025 pm 06:34 PM

L'article traite des tests d'unité d'écriture dans GO, couvrant les meilleures pratiques, des techniques de moquerie et des outils pour une gestion efficace des tests.

Comment écrire des objets et des talons simulés pour les tests en Go? Comment écrire des objets et des talons simulés pour les tests en Go? Mar 10, 2025 pm 05:38 PM

Cet article montre la création de simulations et de talons dans GO pour les tests unitaires. Il met l'accent sur l'utilisation des interfaces, fournit des exemples d'implémentations simulées et discute des meilleures pratiques telles que la tenue de simulations concentrées et l'utilisation de bibliothèques d'assertion. L'articl

Comment puis-je définir des contraintes de type personnalisé pour les génériques en Go? Comment puis-je définir des contraintes de type personnalisé pour les génériques en Go? Mar 10, 2025 pm 03:20 PM

Cet article explore les contraintes de type personnalisé de Go pour les génériques. Il détaille comment les interfaces définissent les exigences de type minimum pour les fonctions génériques, améliorant la sécurité du type et la réutilisabilité du code. L'article discute également des limitations et des meilleures pratiques

Expliquez le but du package de réflexion de Go. Quand utiliseriez-vous la réflexion? Quelles sont les implications de performance? Expliquez le but du package de réflexion de Go. Quand utiliseriez-vous la réflexion? Quelles sont les implications de performance? Mar 25, 2025 am 11:17 AM

L'article traite du package de réflexion de Go, utilisé pour la manipulation d'exécution du code, bénéfique pour la sérialisation, la programmation générique, etc. Il met en garde contre les coûts de performance comme une exécution plus lente et une utilisation de la mémoire plus élevée, conseillant une utilisation judicieuse et la meilleure

Comment puis-je utiliser des outils de traçage pour comprendre le flux d'exécution de mes applications GO? Comment puis-je utiliser des outils de traçage pour comprendre le flux d'exécution de mes applications GO? Mar 10, 2025 pm 05:36 PM

Cet article explore l'utilisation d'outils de traçage pour analyser le flux d'exécution des applications GO. Il traite des techniques d'instrumentation manuelles et automatiques, de comparaison d'outils comme Jaeger, Zipkin et OpenTelelemetry, et mettant en évidence une visualisation efficace des données

Comment utilisez-vous des tests basés sur la table dans GO? Comment utilisez-vous des tests basés sur la table dans GO? Mar 21, 2025 pm 06:35 PM

L'article discute de l'utilisation de tests basés sur la table dans GO, une méthode qui utilise un tableau des cas de test pour tester les fonctions avec plusieurs entrées et résultats. Il met en évidence des avantages comme une amélioration de la lisibilité, une duplication réduite, l'évolutivité, la cohérence et un

Comment spécifiez-vous les dépendances dans votre fichier go.mod? Comment spécifiez-vous les dépendances dans votre fichier go.mod? Mar 27, 2025 pm 07:14 PM

L'article discute de la gestion des dépendances des modules GO via Go.mod, couvrant les spécifications, les mises à jour et la résolution des conflits. Il met l'accent sur les meilleures pratiques telles que le versioning sémantique et les mises à jour régulières.

See all articles