Benutzerdefinierte Variablen via Trigger löschen Bugfix 2
authorMoritz Bunkus <m.bunkus@linet-services.de>
Wed, 3 Dec 2014 11:25:57 +0000 (12:25 +0100)
committerMoritz Bunkus <m.bunkus@linet-services.de>
Wed, 3 Dec 2014 11:25:57 +0000 (12:25 +0100)
Die Triggerfunktion selber sollte aus Performancegründen nicht »DELETE …
WHERE … IN (SELECT…)« nutzen, da dies bei PostgreSQL sehr langsam ist.

sql/Pg-upgrade2/delete_cvars_on_trans_deletion_fix2.sql [new file with mode: 0644]

diff --git a/sql/Pg-upgrade2/delete_cvars_on_trans_deletion_fix2.sql b/sql/Pg-upgrade2/delete_cvars_on_trans_deletion_fix2.sql
new file mode 100644 (file)
index 0000000..b0e5935
--- /dev/null
@@ -0,0 +1,16 @@
+-- @tag: delete_cvars_on_trans_deletion_fix2
+-- @description: Bugfix 2 für das Löschen von benutzerdefinierten Variablen via Triggerfunktionen
+-- @depends: delete_cvars_on_trans_deletion_fix1
+
+-- 2.1. Parametrisierte Backend-Funktion zum Löschen:
+CREATE OR REPLACE FUNCTION delete_custom_variables_with_sub_module(config_module TEXT, cvar_sub_module TEXT, old_id INTEGER)
+RETURNS BOOLEAN AS $$
+  BEGIN
+    DELETE FROM custom_variables
+    WHERE EXISTS (SELECT id FROM custom_variable_configs cfg WHERE (cfg.module = config_module) AND (custom_variables.config_id = cfg.id))
+      AND (COALESCE(sub_module, '') = cvar_sub_module)
+      AND (trans_id                 = old_id);
+
+    RETURN TRUE;
+  END;
+$$ LANGUAGE plpgsql;