首頁 > 後端開發 > Golang > 主體

如何修復使用 Goose 和 PostgreSQL 建立預存程序時的「未終止字串」錯誤?

Patricia Arquette
發布: 2024-11-03 01:30:29
原創
752 人瀏覽過

How to Fix the

Postgres Goose 引發未終止字串錯誤

問題

嘗試使用PostgreSQL 資料庫透過Goose 建立儲存程序時,此程序遇到下列情況錯誤:

(pq: unterminated dollar-quoted string at or near "$BODY$
BEGIN
    LOOP
        -- first try to update the key
        UPDATE userslocations SET count = count+1 WHERE userid = user_id AND locationid = location_id;
"), quitting migration.
登入後複製

原因

從pq 函式庫回顯的Goose 錯誤表示SQL 格式錯誤。具體來說,包含分號的複雜語句需要在Goose 中進行特殊註解:

解決方案

要修正錯誤,請以下列方式註解SQL:

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 正確處理SQL,解決未終止的字串錯誤。

以上是如何修復使用 Goose 和 PostgreSQL 建立預存程序時的「未終止字串」錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!