"Si un trabajador quiere hacer bien su trabajo, primero debe afilar sus herramientas." - Confucio, "Las Analectas de Confucio. Lu Linggong"
Página delantera > Programación > ¿Cómo resolver errores de \"cadena cotizada en dólares no terminada\" en funciones PostgreSQL con Goose?

¿Cómo resolver errores de \"cadena cotizada en dólares no terminada\" en funciones PostgreSQL con Goose?

Publicado el 2024-11-17
Navegar:530

How to Resolve \

Cadena cotizada en dólares sin terminar: resolución de errores con punto y coma

En el contexto de la creación de una función PostgreSQL con Goose, este artículo aborda un error encontrado al procesar una declaración compleja dentro del cuerpo de la función. El error, reportado por la biblioteca pq, indica que una cadena cotizada en dólares permanece sin terminar.

Para resolver este problema, tenga en cuenta que las declaraciones complejas que incluyen punto y coma requieren anotaciones usando "-- goose StatementBegin" y "-- goose Anotaciones StatementEnd", según la documentación de Goose. Estas anotaciones ayudan a Goose a administrar el punto y coma incrustados dentro de las sentencias SQL, evitando errores de libpq.

Aplicar estas anotaciones al ejemplo de código proporcionado resuelve el error:

CREATE OR REPLACE FUNCTION add_userlocation(user_id INT, location_id INT) RETURNS VOID AS
$BODY$
--  goose StatementBegin
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;
--  goose StatementEnd
END;
$BODY$
LANGUAGE plpgsql;
Último tutorial Más>

Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.

Copyright© 2022 湘ICP备2022001581号-3