「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > Goose を使用して PostgreSQL 関数の「Unterminated Dollar-Quoted String」エラーを解決する方法

Goose を使用して PostgreSQL 関数の「Unterminated Dollar-Quoted String」エラーを解決する方法

2024 年 11 月 17 日に公開
ブラウズ:695

How to Resolve \

終端のないドル引用符付き文字列: セミコロンによるエラーの解決

Goose で PostgreSQL 関数を作成するというコンテキストで、この記事ではエラーに対処します関数本体内の複雑なステートメントの処理中に発生しました。 pq ライブラリによって報告されたこのエラーは、ドル引用符で囲まれた文字列が終了していないことを示しています。

この問題を解決するには、セミコロンを含む複雑なステートメントには、「-- goose StatementBegin」および「-- goose」を使用した注釈が必要であることに注意してください。 StatementEnd" アノテーション (Goose ドキュメントに従って)。これらの注釈は、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;
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3