-
+
The Information Schema
+
+
triggered_update_columns
+
+ For triggers in the current database that specify a column list
+ (like UPDATE OF column1, column2), the
+ view triggered_update_columns identifies these
+ columns. Triggers that do not specify a column list are not
+ included in this view. Only those columns are shown that the
+ current user owns or has some non-SELECT privilege on.
+
+
+
+
triggered_update_columns Columns
+
+
+
+ |
+ Name
+ Data Type
+ Description
+
+
+
+
+ |
+ trigger_catalog
+ sql_identifier
+ Name of the database that contains the trigger (always the current database)
+
+
+ |
+ trigger_schema
+ sql_identifier
+ Name of the schema that contains the trigger
+
+
+ |
+ trigger_name
+ sql_identifier
+ Name of the trigger
+
+
+ |
+ event_object_catalog
+ sql_identifier
+
+ Name of the database that contains the table that the trigger
+ is defined on (always the current database)
+
+
+
+ |
+ event_object_schema
+ sql_identifier
+ Name of the schema that contains the table that the trigger is defined on
+
+
+ |
+ event_object_table
+ sql_identifier
+ Name of the table that the trigger is defined on
+
+
+ |
+ event_object_column
+ sql_identifier
+ Name of the column that the trigger is defined on
+
+
+
+
+
+
triggers
*
* Copyright (c) 2003-2009, PostgreSQL Global Development Group
*
- * $PostgreSQL: pgsql/src/backend/catalog/information_schema.sql,v 1.61 2009/12/30 22:48:10 petere Exp $
+ * $PostgreSQL: pgsql/src/backend/catalog/information_schema.sql,v 1.62 2009/12/31 14:41:23 petere Exp $
*/
/*
CREATE VIEW triggered_update_columns AS
SELECT CAST(current_database() AS sql_identifier) AS trigger_catalog,
- CAST(null AS sql_identifier) AS trigger_schema,
- CAST(null AS sql_identifier) AS trigger_name,
+ CAST(n.nspname AS sql_identifier) AS trigger_schema,
+ CAST(t.tgname AS sql_identifier) AS trigger_name,
CAST(current_database() AS sql_identifier) AS event_object_catalog,
- CAST(null AS sql_identifier) AS event_object_schema,
- CAST(null AS sql_identifier) AS event_object_table,
- CAST(null AS sql_identifier) AS event_object_column
- WHERE false;
+ CAST(n.nspname AS sql_identifier) AS event_object_schema,
+ CAST(c.relname AS sql_identifier) AS event_object_table,
+ CAST(a.attname AS sql_identifier) AS event_object_column
+
+ FROM pg_namespace n, pg_class c, pg_trigger t,
+ (SELECT tgoid, (ta0.tgat).x AS tgattnum, (ta0.tgat).n AS tgattpos
+ FROM (SELECT oid AS tgoid, information_schema._pg_expandarray(tgattr) AS tgat FROM pg_trigger) AS ta0) AS ta,
+ pg_attribute a
+
+ WHERE n.oid = c.relnamespace
+ AND c.oid = t.tgrelid
+ AND t.oid = ta.tgoid
+ AND (a.attrelid, a.attnum) = (t.tgrelid, ta.tgattnum)
+ AND NOT t.tgisconstraint
+ AND (NOT pg_is_other_temp_schema(n.oid))
+ AND (pg_has_role(c.relowner, 'USAGE')
+ -- SELECT privilege omitted, per SQL standard
+ OR has_column_privilege(c.oid, a.attnum, 'INSERT, UPDATE, REFERENCES') );
GRANT SELECT ON triggered_update_columns TO PUBLIC;