嘗試使用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中文網其他相關文章!