Commit 262e821d authored by Robert Haas's avatar Robert Haas

Update information_schema queries and system views for new relkind.

The original table partitioning patch overlooked this.

Discussion: http://postgr.es/m/CAG1_KcDJiZB=L6yOUO_bVufj2q2851_xdkfhw0JdcD_2VtKssw@mail.gmail.com

Keith Fiske and Amit Langote, adjusted by me.
parent 9a34123b
...@@ -453,7 +453,7 @@ CREATE VIEW check_constraints AS ...@@ -453,7 +453,7 @@ CREATE VIEW check_constraints AS
AND a.attnum > 0 AND a.attnum > 0
AND NOT a.attisdropped AND NOT a.attisdropped
AND a.attnotnull AND a.attnotnull
AND r.relkind = 'r' AND r.relkind IN ('r', 'P')
AND pg_has_role(r.relowner, 'USAGE'); AND pg_has_role(r.relowner, 'USAGE');
GRANT SELECT ON check_constraints TO PUBLIC; GRANT SELECT ON check_constraints TO PUBLIC;
...@@ -525,7 +525,7 @@ CREATE VIEW column_domain_usage AS ...@@ -525,7 +525,7 @@ CREATE VIEW column_domain_usage AS
AND a.attrelid = c.oid AND a.attrelid = c.oid
AND a.atttypid = t.oid AND a.atttypid = t.oid
AND t.typtype = 'd' AND t.typtype = 'd'
AND c.relkind IN ('r', 'v', 'f') AND c.relkind IN ('r', 'v', 'f', 'P')
AND a.attnum > 0 AND a.attnum > 0
AND NOT a.attisdropped AND NOT a.attisdropped
AND pg_has_role(t.typowner, 'USAGE'); AND pg_has_role(t.typowner, 'USAGE');
...@@ -564,7 +564,7 @@ CREATE VIEW column_privileges AS ...@@ -564,7 +564,7 @@ CREATE VIEW column_privileges AS
pr_c.relowner pr_c.relowner
FROM (SELECT oid, relname, relnamespace, relowner, (aclexplode(coalesce(relacl, acldefault('r', relowner)))).* FROM (SELECT oid, relname, relnamespace, relowner, (aclexplode(coalesce(relacl, acldefault('r', relowner)))).*
FROM pg_class FROM pg_class
WHERE relkind IN ('r', 'v', 'f') WHERE relkind IN ('r', 'v', 'f', 'P')
) pr_c (oid, relname, relnamespace, relowner, grantor, grantee, prtype, grantable), ) pr_c (oid, relname, relnamespace, relowner, grantor, grantee, prtype, grantable),
pg_attribute a pg_attribute a
WHERE a.attrelid = pr_c.oid WHERE a.attrelid = pr_c.oid
...@@ -586,7 +586,7 @@ CREATE VIEW column_privileges AS ...@@ -586,7 +586,7 @@ CREATE VIEW column_privileges AS
) pr_a (attrelid, attname, grantor, grantee, prtype, grantable), ) pr_a (attrelid, attname, grantor, grantee, prtype, grantable),
pg_class c pg_class c
WHERE pr_a.attrelid = c.oid WHERE pr_a.attrelid = c.oid
AND relkind IN ('r', 'v', 'f') AND relkind IN ('r', 'v', 'f', 'P')
) x, ) x,
pg_namespace nc, pg_namespace nc,
pg_authid u_grantor, pg_authid u_grantor,
...@@ -629,7 +629,7 @@ CREATE VIEW column_udt_usage AS ...@@ -629,7 +629,7 @@ CREATE VIEW column_udt_usage AS
WHERE a.attrelid = c.oid WHERE a.attrelid = c.oid
AND a.atttypid = t.oid AND a.atttypid = t.oid
AND nc.oid = c.relnamespace AND nc.oid = c.relnamespace
AND a.attnum > 0 AND NOT a.attisdropped AND c.relkind in ('r', 'v', 'f') AND a.attnum > 0 AND NOT a.attisdropped AND c.relkind in ('r', 'v', 'f', 'P')
AND pg_has_role(coalesce(bt.typowner, t.typowner), 'USAGE'); AND pg_has_role(coalesce(bt.typowner, t.typowner), 'USAGE');
GRANT SELECT ON column_udt_usage TO PUBLIC; GRANT SELECT ON column_udt_usage TO PUBLIC;
...@@ -738,7 +738,7 @@ CREATE VIEW columns AS ...@@ -738,7 +738,7 @@ CREATE VIEW columns AS
CAST('NEVER' AS character_data) AS is_generated, CAST('NEVER' AS character_data) AS is_generated,
CAST(null AS character_data) AS generation_expression, CAST(null AS character_data) AS generation_expression,
CAST(CASE WHEN c.relkind = 'r' OR CAST(CASE WHEN c.relkind IN ('r', 'P') OR
(c.relkind IN ('v', 'f') AND (c.relkind IN ('v', 'f') AND
pg_column_is_updatable(c.oid, a.attnum, false)) pg_column_is_updatable(c.oid, a.attnum, false))
THEN 'YES' ELSE 'NO' END AS yes_or_no) AS is_updatable THEN 'YES' ELSE 'NO' END AS yes_or_no) AS is_updatable
...@@ -753,7 +753,7 @@ CREATE VIEW columns AS ...@@ -753,7 +753,7 @@ CREATE VIEW columns AS
WHERE (NOT pg_is_other_temp_schema(nc.oid)) WHERE (NOT pg_is_other_temp_schema(nc.oid))
AND a.attnum > 0 AND NOT a.attisdropped AND c.relkind in ('r', 'v', 'f') AND a.attnum > 0 AND NOT a.attisdropped AND c.relkind in ('r', 'v', 'f', 'P')
AND (pg_has_role(c.relowner, 'USAGE') AND (pg_has_role(c.relowner, 'USAGE')
OR has_column_privilege(c.oid, a.attnum, OR has_column_privilege(c.oid, a.attnum,
...@@ -789,7 +789,7 @@ CREATE VIEW constraint_column_usage AS ...@@ -789,7 +789,7 @@ CREATE VIEW constraint_column_usage AS
AND d.objid = c.oid AND d.objid = c.oid
AND c.connamespace = nc.oid AND c.connamespace = nc.oid
AND c.contype = 'c' AND c.contype = 'c'
AND r.relkind = 'r' AND r.relkind IN ('r', 'P')
AND NOT a.attisdropped AND NOT a.attisdropped
UNION ALL UNION ALL
...@@ -805,7 +805,7 @@ CREATE VIEW constraint_column_usage AS ...@@ -805,7 +805,7 @@ CREATE VIEW constraint_column_usage AS
ELSE r.oid = c.conrelid AND a.attnum = ANY (c.conkey) END) ELSE r.oid = c.conrelid AND a.attnum = ANY (c.conkey) END)
AND NOT a.attisdropped AND NOT a.attisdropped
AND c.contype IN ('p', 'u', 'f') AND c.contype IN ('p', 'u', 'f')
AND r.relkind = 'r' AND r.relkind IN ('r', 'P')
) AS x (tblschema, tblname, tblowner, colname, cstrschema, cstrname) ) AS x (tblschema, tblname, tblowner, colname, cstrschema, cstrname)
...@@ -841,7 +841,7 @@ CREATE VIEW constraint_table_usage AS ...@@ -841,7 +841,7 @@ CREATE VIEW constraint_table_usage AS
WHERE c.connamespace = nc.oid AND r.relnamespace = nr.oid WHERE c.connamespace = nc.oid AND r.relnamespace = nr.oid
AND ( (c.contype = 'f' AND c.confrelid = r.oid) AND ( (c.contype = 'f' AND c.confrelid = r.oid)
OR (c.contype IN ('p', 'u') AND c.conrelid = r.oid) ) OR (c.contype IN ('p', 'u') AND c.conrelid = r.oid) )
AND r.relkind = 'r' AND r.relkind IN ('r', 'P')
AND pg_has_role(r.relowner, 'USAGE'); AND pg_has_role(r.relowner, 'USAGE');
GRANT SELECT ON constraint_table_usage TO PUBLIC; GRANT SELECT ON constraint_table_usage TO PUBLIC;
...@@ -1058,7 +1058,7 @@ CREATE VIEW key_column_usage AS ...@@ -1058,7 +1058,7 @@ CREATE VIEW key_column_usage AS
AND r.oid = c.conrelid AND r.oid = c.conrelid
AND nc.oid = c.connamespace AND nc.oid = c.connamespace
AND c.contype IN ('p', 'u', 'f') AND c.contype IN ('p', 'u', 'f')
AND r.relkind = 'r' AND r.relkind IN ('r', 'P')
AND (NOT pg_is_other_temp_schema(nr.oid)) ) AS ss AND (NOT pg_is_other_temp_schema(nr.oid)) ) AS ss
WHERE ss.roid = a.attrelid WHERE ss.roid = a.attrelid
AND a.attnum = (ss.x).x AND a.attnum = (ss.x).x
...@@ -1774,7 +1774,7 @@ CREATE VIEW table_constraints AS ...@@ -1774,7 +1774,7 @@ CREATE VIEW table_constraints AS
WHERE nc.oid = c.connamespace AND nr.oid = r.relnamespace WHERE nc.oid = c.connamespace AND nr.oid = r.relnamespace
AND c.conrelid = r.oid AND c.conrelid = r.oid
AND c.contype NOT IN ('t', 'x') -- ignore nonstandard constraints AND c.contype NOT IN ('t', 'x') -- ignore nonstandard constraints
AND r.relkind = 'r' AND r.relkind IN ('r', 'P')
AND (NOT pg_is_other_temp_schema(nr.oid)) AND (NOT pg_is_other_temp_schema(nr.oid))
AND (pg_has_role(r.relowner, 'USAGE') AND (pg_has_role(r.relowner, 'USAGE')
-- SELECT privilege omitted, per SQL standard -- SELECT privilege omitted, per SQL standard
...@@ -1804,7 +1804,7 @@ CREATE VIEW table_constraints AS ...@@ -1804,7 +1804,7 @@ CREATE VIEW table_constraints AS
AND a.attnotnull AND a.attnotnull
AND a.attnum > 0 AND a.attnum > 0
AND NOT a.attisdropped AND NOT a.attisdropped
AND r.relkind = 'r' AND r.relkind IN ('r', 'P')
AND (NOT pg_is_other_temp_schema(nr.oid)) AND (NOT pg_is_other_temp_schema(nr.oid))
AND (pg_has_role(r.relowner, 'USAGE') AND (pg_has_role(r.relowner, 'USAGE')
-- SELECT privilege omitted, per SQL standard -- SELECT privilege omitted, per SQL standard
...@@ -1854,7 +1854,7 @@ CREATE VIEW table_privileges AS ...@@ -1854,7 +1854,7 @@ CREATE VIEW table_privileges AS
) AS grantee (oid, rolname) ) AS grantee (oid, rolname)
WHERE c.relnamespace = nc.oid WHERE c.relnamespace = nc.oid
AND c.relkind IN ('r', 'v') AND c.relkind IN ('r', 'v', 'P')
AND c.grantee = grantee.oid AND c.grantee = grantee.oid
AND c.grantor = u_grantor.oid AND c.grantor = u_grantor.oid
AND c.prtype IN ('INSERT', 'SELECT', 'UPDATE', 'DELETE', 'TRUNCATE', 'REFERENCES', 'TRIGGER') AND c.prtype IN ('INSERT', 'SELECT', 'UPDATE', 'DELETE', 'TRUNCATE', 'REFERENCES', 'TRIGGER')
...@@ -1898,7 +1898,7 @@ CREATE VIEW tables AS ...@@ -1898,7 +1898,7 @@ CREATE VIEW tables AS
CAST( CAST(
CASE WHEN nc.oid = pg_my_temp_schema() THEN 'LOCAL TEMPORARY' CASE WHEN nc.oid = pg_my_temp_schema() THEN 'LOCAL TEMPORARY'
WHEN c.relkind = 'r' THEN 'BASE TABLE' WHEN c.relkind IN ('r', 'P') THEN 'BASE TABLE'
WHEN c.relkind = 'v' THEN 'VIEW' WHEN c.relkind = 'v' THEN 'VIEW'
WHEN c.relkind = 'f' THEN 'FOREIGN TABLE' WHEN c.relkind = 'f' THEN 'FOREIGN TABLE'
ELSE null END ELSE null END
...@@ -1911,7 +1911,7 @@ CREATE VIEW tables AS ...@@ -1911,7 +1911,7 @@ CREATE VIEW tables AS
CAST(nt.nspname AS sql_identifier) AS user_defined_type_schema, CAST(nt.nspname AS sql_identifier) AS user_defined_type_schema,
CAST(t.typname AS sql_identifier) AS user_defined_type_name, CAST(t.typname AS sql_identifier) AS user_defined_type_name,
CAST(CASE WHEN c.relkind = 'r' OR CAST(CASE WHEN c.relkind IN ('r', 'P') OR
(c.relkind IN ('v', 'f') AND (c.relkind IN ('v', 'f') AND
-- 1 << CMD_INSERT -- 1 << CMD_INSERT
pg_relation_is_updatable(c.oid, false) & 8 = 8) pg_relation_is_updatable(c.oid, false) & 8 = 8)
...@@ -1923,7 +1923,7 @@ CREATE VIEW tables AS ...@@ -1923,7 +1923,7 @@ CREATE VIEW tables AS
FROM pg_namespace nc JOIN pg_class c ON (nc.oid = c.relnamespace) FROM pg_namespace nc JOIN pg_class c ON (nc.oid = c.relnamespace)
LEFT JOIN (pg_type t JOIN pg_namespace nt ON (t.typnamespace = nt.oid)) ON (c.reloftype = t.oid) LEFT JOIN (pg_type t JOIN pg_namespace nt ON (t.typnamespace = nt.oid)) ON (c.reloftype = t.oid)
WHERE c.relkind IN ('r', 'v', 'f') WHERE c.relkind IN ('r', 'v', 'f', 'P')
AND (NOT pg_is_other_temp_schema(nc.oid)) AND (NOT pg_is_other_temp_schema(nc.oid))
AND (pg_has_role(c.relowner, 'USAGE') AND (pg_has_role(c.relowner, 'USAGE')
OR has_table_privilege(c.oid, 'SELECT, INSERT, UPDATE, DELETE, TRUNCATE, REFERENCES, TRIGGER') OR has_table_privilege(c.oid, 'SELECT, INSERT, UPDATE, DELETE, TRUNCATE, REFERENCES, TRIGGER')
...@@ -2442,7 +2442,7 @@ CREATE VIEW view_column_usage AS ...@@ -2442,7 +2442,7 @@ CREATE VIEW view_column_usage AS
AND dt.refclassid = 'pg_catalog.pg_class'::regclass AND dt.refclassid = 'pg_catalog.pg_class'::regclass
AND dt.refobjid = t.oid AND dt.refobjid = t.oid
AND t.relnamespace = nt.oid AND t.relnamespace = nt.oid
AND t.relkind IN ('r', 'v', 'f') AND t.relkind IN ('r', 'v', 'f', 'P')
AND t.oid = a.attrelid AND t.oid = a.attrelid
AND dt.refobjsubid = a.attnum AND dt.refobjsubid = a.attnum
AND pg_has_role(t.relowner, 'USAGE'); AND pg_has_role(t.relowner, 'USAGE');
...@@ -2520,7 +2520,7 @@ CREATE VIEW view_table_usage AS ...@@ -2520,7 +2520,7 @@ CREATE VIEW view_table_usage AS
AND dt.refclassid = 'pg_catalog.pg_class'::regclass AND dt.refclassid = 'pg_catalog.pg_class'::regclass
AND dt.refobjid = t.oid AND dt.refobjid = t.oid
AND t.relnamespace = nt.oid AND t.relnamespace = nt.oid
AND t.relkind IN ('r', 'v', 'f') AND t.relkind IN ('r', 'v', 'f', 'P')
AND pg_has_role(t.relowner, 'USAGE'); AND pg_has_role(t.relowner, 'USAGE');
GRANT SELECT ON view_table_usage TO PUBLIC; GRANT SELECT ON view_table_usage TO PUBLIC;
...@@ -2673,7 +2673,7 @@ CREATE VIEW element_types AS ...@@ -2673,7 +2673,7 @@ CREATE VIEW element_types AS
a.attnum, a.atttypid, a.attcollation a.attnum, a.atttypid, a.attcollation
FROM pg_class c, pg_attribute a FROM pg_class c, pg_attribute a
WHERE c.oid = a.attrelid WHERE c.oid = a.attrelid
AND c.relkind IN ('r', 'v', 'f', 'c') AND c.relkind IN ('r', 'v', 'f', 'c', 'P')
AND attnum > 0 AND NOT attisdropped AND attnum > 0 AND NOT attisdropped
UNION ALL UNION ALL
......
...@@ -136,7 +136,7 @@ CREATE VIEW pg_tables AS ...@@ -136,7 +136,7 @@ CREATE VIEW pg_tables AS
C.relrowsecurity AS rowsecurity C.relrowsecurity AS rowsecurity
FROM pg_class C LEFT JOIN pg_namespace N ON (N.oid = C.relnamespace) FROM pg_class C LEFT JOIN pg_namespace N ON (N.oid = C.relnamespace)
LEFT JOIN pg_tablespace T ON (T.oid = C.reltablespace) LEFT JOIN pg_tablespace T ON (T.oid = C.reltablespace)
WHERE C.relkind = 'r'; WHERE C.relkind IN ('r', 'P');
CREATE VIEW pg_matviews AS CREATE VIEW pg_matviews AS
SELECT SELECT
...@@ -280,7 +280,7 @@ CREATE VIEW pg_prepared_statements AS ...@@ -280,7 +280,7 @@ CREATE VIEW pg_prepared_statements AS
CREATE VIEW pg_seclabels AS CREATE VIEW pg_seclabels AS
SELECT SELECT
l.objoid, l.classoid, l.objsubid, l.objoid, l.classoid, l.objsubid,
CASE WHEN rel.relkind = 'r' THEN 'table'::text CASE WHEN rel.relkind IN ('r', 'P') THEN 'table'::text
WHEN rel.relkind = 'v' THEN 'view'::text WHEN rel.relkind = 'v' THEN 'view'::text
WHEN rel.relkind = 'm' THEN 'materialized view'::text WHEN rel.relkind = 'm' THEN 'materialized view'::text
WHEN rel.relkind = 'S' THEN 'sequence'::text WHEN rel.relkind = 'S' THEN 'sequence'::text
......
...@@ -1463,7 +1463,7 @@ pg_seclabels| SELECT l.objoid, ...@@ -1463,7 +1463,7 @@ pg_seclabels| SELECT l.objoid,
l.classoid, l.classoid,
l.objsubid, l.objsubid,
CASE CASE
WHEN (rel.relkind = 'r'::"char") THEN 'table'::text WHEN (rel.relkind = ANY (ARRAY['r'::"char", 'P'::"char"])) THEN 'table'::text
WHEN (rel.relkind = 'v'::"char") THEN 'view'::text WHEN (rel.relkind = 'v'::"char") THEN 'view'::text
WHEN (rel.relkind = 'm'::"char") THEN 'materialized view'::text WHEN (rel.relkind = 'm'::"char") THEN 'materialized view'::text
WHEN (rel.relkind = 'S'::"char") THEN 'sequence'::text WHEN (rel.relkind = 'S'::"char") THEN 'sequence'::text
...@@ -2139,7 +2139,7 @@ pg_tables| SELECT n.nspname AS schemaname, ...@@ -2139,7 +2139,7 @@ pg_tables| SELECT n.nspname AS schemaname,
FROM ((pg_class c FROM ((pg_class c
LEFT JOIN pg_namespace n ON ((n.oid = c.relnamespace))) LEFT JOIN pg_namespace n ON ((n.oid = c.relnamespace)))
LEFT JOIN pg_tablespace t ON ((t.oid = c.reltablespace))) LEFT JOIN pg_tablespace t ON ((t.oid = c.reltablespace)))
WHERE (c.relkind = 'r'::"char"); WHERE (c.relkind = ANY (ARRAY['r'::"char", 'P'::"char"]));
pg_timezone_abbrevs| SELECT pg_timezone_abbrevs.abbrev, pg_timezone_abbrevs| SELECT pg_timezone_abbrevs.abbrev,
pg_timezone_abbrevs.utc_offset, pg_timezone_abbrevs.utc_offset,
pg_timezone_abbrevs.is_dst pg_timezone_abbrevs.is_dst
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment