ホームページ >バックエンド開発 >Golang >Goose で PostgreSQL 関数を作成するときに発生する未終了のドル引用符付き文字列エラーを解決するにはどうすればよいですか?

Goose で PostgreSQL 関数を作成するときに発生する未終了のドル引用符付き文字列エラーを解決するにはどうすればよいですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-11-02 16:09:29757ブラウズ

How to Resolve the Unterminated Dollar-Quoted String Error When Creating PostgreSQL Functions in Goose?

Goose の終端のないドル引用符付き文字列エラー: PostgreSQL 関数作成の問題の解決

Goose を使用して PostgreSQL で関数を作成しようとすると、終了していないドル引用符で囲まれた文字列に関連するエラーが発生する可能性があります。このエラーは通常、関数の SQL ステートメントに文字列を分割するセミコロンが含まれている場合に発生します。

この問題を解決するには、Goose ユーザーはこれらの複雑なステートメントに -- goose StatementBegin および -- goose StatementEnd の注釈を付ける必要があります。これらの注釈はステートメントを小さなチャンクに分割し、Goose がステートメントを正しく処理できるようにします。

特定のケースでは、コードの UPDATE ステートメントと INSERT ステートメントにセミコロンが含まれています。したがって、注釈付きコードは次のようになります。

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;
-- +goose StatementEnd
    IF found THEN
        RETURN;
    END IF;
-- +goose StatementBegin
    BEGIN
        INSERT INTO userslocations(userid,locationid, count) VALUES (user_id, location_id, 1);
        RETURN;
    EXCEPTION WHEN unique_violation THEN
-- +goose StatementEnd
    END;
    END LOOP;
END;
$BODY$
LANGUAGE plpgsql;

これらの注釈が追加されると、Goose は未終了文字列エラーが発生することなく SQL ステートメントを適切に処理し、関数を作成できるようになります。ステートメントに埋め込みセミコロンが含まれている場合は、Goose および pq ライブラリとの互換性を確保するためにこれらの注釈を追加することが重要であることに注意してください。

以上がGoose で PostgreSQL 関数を作成するときに発生する未終了のドル引用符付き文字列エラーを解決するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。