>  기사  >  백엔드 개발  >  Goose를 사용하여 PostgreSQL 함수의 \"종료되지 않은 달러 인용 문자열\" 오류를 해결하는 방법은 무엇입니까?

Goose를 사용하여 PostgreSQL 함수의 \"종료되지 않은 달러 인용 문자열\" 오류를 해결하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-02 15:10:03163검색

How to Resolve

종료되지 않은 달러 인용 문자열: 세미콜론으로 오류 해결

Goose를 사용하여 PostgreSQL 함수를 생성하는 맥락에서 이 문서에서는 오류를 다룹니다. 함수 본문 내에서 복잡한 명령문을 처리하는 동안 발생했습니다. pq 라이브러리에서 보고된 오류는 달러로 묶인 문자열이 종료되지 않은 상태로 남아 있음을 나타냅니다.

이 문제를 해결하려면 세미콜론이 포함된 복잡한 명령문에는 "-- gooseStatementBegin" 및 "-- goose를 사용한 주석이 필요합니다. Goose 문서에 따른 "StatementEnd" 주석. 이러한 주석은 Goose가 SQL 문 내에 포함된 세미콜론을 관리하여 libpq 오류를 방지하는 데 도움이 됩니다.

제공된 코드 샘플에 이러한 주석을 적용하면 오류가 해결됩니다.

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;

위 내용은 Goose를 사용하여 PostgreSQL 함수의 \"종료되지 않은 달러 인용 문자열\" 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.