]> git.xonotic.org Git - xonotic/xonstatdb.git/commitdiff
Fix the triggers for partitioning.
authorAnt Zucaro <azucaro@gmail.com>
Wed, 9 Nov 2011 23:15:55 +0000 (18:15 -0500)
committerAnt Zucaro <azucaro@gmail.com>
Wed, 9 Nov 2011 23:15:55 +0000 (18:15 -0500)
triggers/games_ins_trg.sql
triggers/player_game_stats_ins_trg.sql
triggers/player_weapon_stats_ins_trg.sql

index 17e7c08200f7c7eeadf63b65bfa2cda1f86eb69c..e893c3947ca5be3e290a9b4f3f262e68142156d2 100755 (executable)
@@ -1,23 +1,23 @@
-CREATE OR REPLACE FUNCTION games_ins()\r
+CREATE OR REPLACE FUNCTION games_ins()\r
 RETURNS TRIGGER AS $$\r
 BEGIN\r
-    IF (create_dt >= DATE '2011-04-01' AND create_dt < DATE '2011-07-01') THEN\r
+    IF (NEW.create_dt >= DATE '2011-04-01' AND NEW.create_dt < DATE '2011-07-01') THEN\r
         INSERT INTO games_2011Q2 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2011-07-01' AND create_dt < DATE '2011-10-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2011-07-01' AND NEW.create_dt < DATE '2011-10-01') THEN\r
         INSERT INTO games_2011Q3 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2011-10-01' AND create_dt < DATE '2012-01-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2011-10-01' AND NEW.create_dt < DATE '2012-01-01') THEN\r
         INSERT INTO games_2011Q4 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2012-01-01' AND create_dt < DATE '2012-04-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2012-01-01' AND NEW.create_dt < DATE '2012-04-01') THEN\r
         INSERT INTO games_2012Q1 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2012-04-01' AND create_dt < DATE '2012-07-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2012-04-01' AND NEW.create_dt < DATE '2012-07-01') THEN\r
         INSERT INTO games_2012Q2 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2012-07-01' AND create_dt < DATE '2012-10-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2012-07-01' AND NEW.create_dt < DATE '2012-10-01') THEN\r
         INSERT INTO games_2012Q3 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2012-10-01' AND create_dt < DATE '2013-01-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2012-10-01' AND NEW.create_dt < DATE '2013-01-01') THEN\r
         INSERT INTO games_2012Q4 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2013-01-01' AND create_dt < DATE '2013-04-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2013-01-01' AND NEW.create_dt < DATE '2013-04-01') THEN\r
         INSERT INTO games_2013Q1 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2013-04-01' AND create_dt < DATE '2013-07-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2013-04-01' AND NEW.create_dt < DATE '2013-07-01') THEN\r
         INSERT INTO games_2013Q2 VALUES (NEW.*);\r
     ELSE\r
         RAISE EXCEPTION 'Date out of range.  Fix the games_ins() trigger!';\r
@@ -26,3 +26,8 @@ BEGIN
 END;\r
 $$\r
 LANGUAGE plpgsql;\r
+\r
+DROP TRIGGER IF EXISTS games_ins_trg ON xonstat.games;\r
+CREATE TRIGGER games_ins_trg\r
+    BEFORE INSERT on xonstat.games\r
+    FOR EACH ROW EXECUTE PROCEDURE games_ins();\r
index 8c818f99528e595a073a49d9d7c809f7cfc8505b..e321a306779a670631965bf5cf77890870f34b1a 100755 (executable)
@@ -1,23 +1,23 @@
-CREATE OR REPLACE FUNCTION player_game_stats_ins()\r
+CREATE OR REPLACE FUNCTION player_game_stats_ins()\r
 RETURNS TRIGGER AS $$\r
 BEGIN\r
-    IF (create_dt >= DATE '2011-04-01' AND create_dt < DATE '2011-07-01') THEN\r
+    IF (NEW.create_dt >= DATE '2011-04-01' AND NEW.create_dt < DATE '2011-07-01') THEN\r
         INSERT INTO player_game_stats_2011Q2 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2011-07-01' AND create_dt < DATE '2011-10-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2011-07-01' AND NEW.create_dt < DATE '2011-10-01') THEN\r
         INSERT INTO player_game_stats_2011Q3 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2011-10-01' AND create_dt < DATE '2012-01-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2011-10-01' AND NEW.create_dt < DATE '2012-01-01') THEN\r
         INSERT INTO player_game_stats_2011Q4 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2012-01-01' AND create_dt < DATE '2012-04-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2012-01-01' AND NEW.create_dt < DATE '2012-04-01') THEN\r
         INSERT INTO player_game_stats_2012Q1 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2012-04-01' AND create_dt < DATE '2012-07-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2012-04-01' AND NEW.create_dt < DATE '2012-07-01') THEN\r
         INSERT INTO player_game_stats_2012Q2 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2012-07-01' AND create_dt < DATE '2012-10-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2012-07-01' AND NEW.create_dt < DATE '2012-10-01') THEN\r
         INSERT INTO player_game_stats_2012Q3 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2012-10-01' AND create_dt < DATE '2013-01-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2012-10-01' AND NEW.create_dt < DATE '2013-01-01') THEN\r
         INSERT INTO player_game_stats_2012Q4 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2013-01-01' AND create_dt < DATE '2013-04-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2013-01-01' AND NEW.create_dt < DATE '2013-04-01') THEN\r
         INSERT INTO player_game_stats_2013Q1 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2013-04-01' AND create_dt < DATE '2013-07-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2013-04-01' AND NEW.create_dt < DATE '2013-07-01') THEN\r
         INSERT INTO player_game_stats_2013Q2 VALUES (NEW.*);\r
     ELSE\r
         RAISE EXCEPTION 'Date out of range.  Fix the player_game_stats_ins() trigger!';\r
@@ -26,3 +26,8 @@ BEGIN
 END;\r
 $$\r
 LANGUAGE plpgsql;\r
+\r
+DROP TRIGGER IF EXISTS player_game_stats_ins_trg ON xonstat.player_game_stats;\r
+CREATE TRIGGER player_game_stats_ins_trg\r
+    BEFORE INSERT on xonstat.player_game_stats\r
+    FOR EACH ROW EXECUTE PROCEDURE player_game_stats_ins();\r
index f209b011a8ebdd62bf3bc28612f66c2e5acb9a07..fbaf45195524ba9011a2e6eb33c93c5c7815a5cd 100755 (executable)
@@ -1,23 +1,23 @@
-CREATE OR REPLACE FUNCTION player_weapon_stats_ins()\r
+CREATE OR REPLACE FUNCTION player_weapon_stats_ins()\r
 RETURNS TRIGGER AS $$\r
 BEGIN\r
-    IF (create_dt >= DATE '2011-04-01' AND create_dt < DATE '2011-07-01') THEN\r
+    IF (NEW.create_dt >= DATE '2011-04-01' AND NEW.create_dt < DATE '2011-07-01') THEN\r
         INSERT INTO player_weapon_stats_2011Q2 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2011-07-01' AND create_dt < DATE '2011-10-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2011-07-01' AND NEW.create_dt < DATE '2011-10-01') THEN\r
         INSERT INTO player_weapon_stats_2011Q3 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2011-10-01' AND create_dt < DATE '2012-01-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2011-10-01' AND NEW.create_dt < DATE '2012-01-01') THEN\r
         INSERT INTO player_weapon_stats_2011Q4 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2012-01-01' AND create_dt < DATE '2012-04-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2012-01-01' AND NEW.create_dt < DATE '2012-04-01') THEN\r
         INSERT INTO player_weapon_stats_2012Q1 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2012-04-01' AND create_dt < DATE '2012-07-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2012-04-01' AND NEW.create_dt < DATE '2012-07-01') THEN\r
         INSERT INTO player_weapon_stats_2012Q2 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2012-07-01' AND create_dt < DATE '2012-10-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2012-07-01' AND NEW.create_dt < DATE '2012-10-01') THEN\r
         INSERT INTO player_weapon_stats_2012Q3 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2012-10-01' AND create_dt < DATE '2013-01-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2012-10-01' AND NEW.create_dt < DATE '2013-01-01') THEN\r
         INSERT INTO player_weapon_stats_2012Q4 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2013-01-01' AND create_dt < DATE '2013-04-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2013-01-01' AND NEW.create_dt < DATE '2013-04-01') THEN\r
         INSERT INTO player_weapon_stats_2013Q1 VALUES (NEW.*);\r
-    ELSIF (create_dt >= DATE '2013-04-01' AND create_dt < DATE '2013-07-01') THEN\r
+    ELSIF (NEW.create_dt >= DATE '2013-04-01' AND NEW.create_dt < DATE '2013-07-01') THEN\r
         INSERT INTO player_weapon_stats_2013Q2 VALUES (NEW.*);\r
     ELSE\r
         RAISE EXCEPTION 'Date out of range.  Fix the player_weapon_stats_ins() trigger!';\r
@@ -26,3 +26,8 @@ BEGIN
 END;\r
 $$\r
 LANGUAGE plpgsql;\r
+\r
+DROP TRIGGER IF EXISTS player_weapon_stats_ins_trg ON xonstat.player_weapon_stats;\r
+CREATE TRIGGER player_weapon_stats_ins_trg\r
+    BEFORE INSERT on xonstat.player_weapon_stats\r
+    FOR EACH ROW EXECUTE PROCEDURE player_weapon_stats_ins();\r