Използвайте FROM
клауза на UPDATE
за да се присъедините към temp_zip_type
и zip_code_type
и направете всичко с един прост израз:
UPDATE zip_code z
SET type_id = t.id
FROM temp_zip_type tmp
JOIN zip_code_type t ON t.value = tmp.temp_type
WHERE z.zip_5_digit = tmp.temp_zip
AND z.type_id IS DISTINCT FROM t.id; -- avoid empty updates
Добавих последния ред, за да избегна празни актуализации. Може или не може да бъде полезно. Подробности: