Maison > développement back-end > Golang > le corps du texte

Comment résoudre l'erreur « Chaîne non terminée en dollars cités » dans les fonctions PostgreSQL à l'aide de Goose ?

Linda Hamilton
Libérer: 2024-11-03 20:45:29
original
224 Les gens l'ont consulté

How to Resolve

Erreur de chaîne non terminée avec citation en dollars résolue avec -- Annotations goose

Une tentative de création d'une fonction PostgreSQL à l'aide de Goose rencontre un "dollar non terminé "-chaîne citée". Le code de la fonction implique une construction en boucle, des vérifications conditionnelles et un bloc d'exception limité, qui introduit des points-virgules dans l'instruction.

Explication

La documentation Goose précise que le code SQL complexe les instructions qui incluent des points-virgules doivent être délimitées par les annotations spéciales -- goose StatementBegin et -- goose StatementEnd. Ces annotations empêchent Goose de modifier le SQL d'une manière qui déclencherait des erreurs avec la bibliothèque de base de données pq.

Solution

Pour résoudre l'erreur, modifiez le code de la fonction pour inclure les annotations comme suit :

CREATE OR REPLACE FUNCTION add_userlocation(user_id INT, location_id INT) RETURNS VOID AS
-- +goose StatementBegin
$BODY$
BEGIN
    LOOP
        UPDATE userslocations SET count = count+1 WHERE userid = user_id AND locationid = location_id;
        IF found THEN
            RETURN;
        END IF;
        BEGIN
            INSERT INTO userslocations(userid,locationid, count) VALUES (user_id, location_id, 1);
            RETURN;
        EXCEPTION WHEN unique_violation THEN
        END;
    END LOOP;
END;
-- +goose StatementEnd
$BODY$
LANGUAGE plpgsql;
Copier après la connexion

En annotant le début et la fin de l'instruction complexe, Goose gérera le traitement SQL de manière appropriée, empêchant la bibliothèque pq de rencontrer l'erreur de chaîne non terminée.

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!

source:php.cn
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!