Оператор with работает с несколькими командами sql? Мне нужно удалить записи в 2-х таблицах. Мой sql выглядит так:
with tbd as (
SELECT (row_value ->> 'id')::INTEGER
FROM public.row_history
where record_table = 'survey_storage'
and row_value ->> 'status' = 'Never Surveyed'
except
(SELECT (row_value ->> 'id')::INTEGER
FROM public.row_history
where record_table = 'survey_storage'
and row_value ->> 'status' = 'Ready to Launch')
limit 1)
delete from row_history where (row_value ->> 'id')::INTEGER = ANY(ARRAY(select * from tbd))
delete from survey_storage where id = ANY(ARRAY(select * from tbd))
Это не работает. Из двух операторов удаления, если вы закомментируете один, то другой работает. Но вместе они даже не компилируются. Определенно, я могу написать 2 sql скрипта, каждый с одним удалением, но я хочу сделать это за один go. Я получаю эту ошибку:
SQL Error [42601]: ERROR: syntax error at or near "delete"
Position: 410
ERROR: syntax error at or near "delete"
Position: 410
ERROR: syntax error at or near "delete"
Position: 410