Я пытаюсь добавить третий параметр в следующую функцию SQL:
CREATE OR REPLACE FUNCTION community.publish_photo_story(
p_story_id BIGINT,
p_author_id INT
)
RETURNS TABLE (
status VARCHAR(25),
message VARCHAR(255)
)
AS
$func$
DECLARE
v_photo_id BIGINT;
v_caption TEXT;
v_primary_photo VARCHAR(255);
v_thumbnail_photo VARCHAR(255);
v_tag_codes VARCHAR[];
v_tag_ids INT[];
v_status VARCHAR(25) := 'success';
v_message VARCHAR(255) := 'Photo Story has been successfully published';
BEGIN
IF NOT EXISTS (
SELECT 1 FROM community.story
WHERE story_id = p_story_id
AND published_state = 'in-progress'
AND is_deleted = false
AND author_id = p_author_id) THEN
v_status := 'error';
v_message := 'The story cannot be published';
RETURN QUERY SELECT v_status, v_message;
RETURN;
END IF;
SELECT photo_id, caption INTO v_photo_id, v_caption
FROM community.moment
WHERE story_id = p_story_id
ORDER BY display_order ASC
LIMIT 1;
SELECT b_secured_url, t_secured_url INTO v_primary_photo, v_thumbnail_photo
FROM core.photo
WHERE photo_id = v_photo_id;
WITH tags AS (
SELECT c.tag_id, c.tag_code
FROM community.story_tag as ct
INNER JOIN community.tag as c
ON ct.tag_id = c.tag_id
WHERE ct.story_id = p_story_id
) SELECT
array_agg(tag_id),
array_agg(tag_code)
INTO
v_tag_ids,
v_tag_codes
FROM tags;
UPDATE community.post
SET post_text = concat(v_caption),
last_updated_date = now()
WHERE story_id = p_story_id;
-- Substring caption to 160 chars for preview content
IF length(v_caption) > 160 THEN
v_caption := concat(substr(v_caption, 0, 160), '...');
END IF;
UPDATE community.story
SET
preview_content = v_caption,
primary_photo = v_primary_photo,
thumbnail_photo = v_thumbnail_photo,
published_state = 'done',
last_updated_date = now()
WHERE story_id = p_story_id;
INSERT INTO audit.story_history(
story_id,
acted_by_id,
log_message)
VALUES(
p_story_id,
p_author_id,
'Photo story has been published');
RETURN QUERY SELECT v_status, v_message;
END;
$func$ LANGUAGE plpgsql;
Я должен добавить новый параметр primary_photo
, и это означает, что я должен изменить параметры следующим образом: CREATE OR REPLACE FUNCTION community.publish_photo_story(p_story_id BIGINT, p_author_id INT, p_primary_photo VARCHAR)
. Тем не менее, я все еще в замешательстве, если я все еще сохраню часть, где я объявляю переменную v_primary_photo VARCHAR(255)
. Я бы пропустил его, если бы не тот факт, что на v_primary_photo
ссылаются несколько раз в других местах.
Короче говоря, как мне убедиться, что любой существующий экземпляр v_primary_photo
будет иметь значение нового параметра p_primary_photo
?