postgresql_delete_trigger.sql 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. --#############################################################################
  2. -- Create trigger for automated deletion of dependent rows
  3. --
  4. -- Author: Soeren Gebbert soerengebbert <at> googlemail <dot> com
  5. --#############################################################################
  6. CREATE OR REPLACE FUNCTION delete_strds_base() RETURNS TRIGGER AS $$
  7. BEGIN
  8. DELETE FROM strds_absolute_time WHERE id = OLD.id;
  9. DELETE FROM strds_relative_time WHERE id = OLD.id;
  10. DELETE FROM strds_spatial_extent WHERE id = OLD.id;
  11. DELETE FROM strds_metadata WHERE id = OLD.id;
  12. RETURN OLD;
  13. END;
  14. $$ LANGUAGE plpgsql;
  15. CREATE OR REPLACE FUNCTION delete_raster_base() RETURNS TRIGGER AS $$
  16. BEGIN
  17. DELETE FROM raster_absolute_time WHERE id = OLD.id;
  18. DELETE FROM raster_relative_time WHERE id = OLD.id;
  19. DELETE FROM raster_spatial_extent WHERE id = OLD.id;
  20. DELETE FROM raster_metadata WHERE id = OLD.id;
  21. DELETE FROM raster_stds_register WHERE id = OLD.id;
  22. RETURN OLD;
  23. END;
  24. $$ LANGUAGE plpgsql;
  25. CREATE OR REPLACE FUNCTION delete_str3ds_base() RETURNS TRIGGER AS $$
  26. BEGIN
  27. DELETE FROM str3ds_absolute_time WHERE id = OLD.id;
  28. DELETE FROM str3ds_relative_time WHERE id = OLD.id;
  29. DELETE FROM str3ds_spatial_extent WHERE id = OLD.id;
  30. DELETE FROM str3ds_metadata WHERE id = OLD.id;
  31. RETURN OLD;
  32. END;
  33. $$ LANGUAGE plpgsql;
  34. CREATE OR REPLACE FUNCTION delete_raster3d_base() RETURNS TRIGGER AS $$
  35. BEGIN
  36. DELETE FROM raster3d_absolute_time WHERE id = OLD.id;
  37. DELETE FROM raster3d_relative_time WHERE id = OLD.id;
  38. DELETE FROM raster3d_spatial_extent WHERE id = OLD.id;
  39. DELETE FROM raster3d_metadata WHERE id = OLD.id;
  40. DELETE FROM raster3d_stds_register WHERE id = OLD.id;
  41. RETURN OLD;
  42. END;
  43. $$ LANGUAGE plpgsql;
  44. CREATE OR REPLACE FUNCTION delete_stvds_base() RETURNS TRIGGER AS $$
  45. BEGIN
  46. DELETE FROM stvds_absolute_time WHERE id = OLD.id;
  47. DELETE FROM stvds_relative_time WHERE id = OLD.id;
  48. DELETE FROM stvds_spatial_extent WHERE id = OLD.id;
  49. DELETE FROM stvds_metadata WHERE id = OLD.id;
  50. RETURN OLD;
  51. END;
  52. $$ LANGUAGE plpgsql;
  53. CREATE OR REPLACE FUNCTION delete_vector_base() RETURNS TRIGGER AS $$
  54. BEGIN
  55. DELETE FROM vector_absolute_time WHERE id = OLD.id;
  56. DELETE FROM vector_relative_time WHERE id = OLD.id;
  57. DELETE FROM vector_spatial_extent WHERE id = OLD.id;
  58. DELETE FROM vector_metadata WHERE id = OLD.id;
  59. DELETE FROM vector_stds_register WHERE id = OLD.id;
  60. RETURN OLD;
  61. END;
  62. $$ LANGUAGE plpgsql;
  63. CREATE TRIGGER delete_strds_base AFTER DELETE ON strds_base FOR EACH ROW EXECUTE PROCEDURE delete_strds_base();
  64. CREATE TRIGGER delete_raster_base AFTER DELETE ON raster_base FOR EACH ROW EXECUTE PROCEDURE delete_raster_base();
  65. CREATE TRIGGER delete_str3ds_base AFTER DELETE ON str3ds_base FOR EACH ROW EXECUTE PROCEDURE delete_str3ds_base();
  66. CREATE TRIGGER delete_raster3d_base AFTER DELETE ON raster3d_base FOR EACH ROW EXECUTE PROCEDURE delete_raster3d_base();
  67. CREATE TRIGGER delete_stvds_base AFTER DELETE ON stvds_base FOR EACH ROW EXECUTE PROCEDURE delete_stvds_base();
  68. CREATE TRIGGER delete_vector_base AFTER DELETE ON vector_base FOR EACH ROW EXECUTE PROCEDURE delete_vector_base();