有很多信息,可以从 information_schema 和 pg_catalog 中检索到postgresql
。我想检索有关由某个索引索引的列的信息,类似于我pragma index_info(<index_name>)
在 sqlite3 中实现的。create index
不解析语句如何实现?
问问题
3569 次
2 回答
7
这些东西很容易找出来。
只需使用该-E
选项运行 psql,它就会向您显示所使用的 SQL 语句。因此,在运行 \d index_name 时,使用以下语句(以及其他语句)来检索索引列:
选择一个.attname, pg_catalog.format_type (a.atttypid,a.atttypmod), (SELECT SUBSTRING(pg_catalog.pg_get_expr(d.adbin,d.adrelid)FOR 128) FROM pg_catalog.pg_attrdef d WHERE d.adrelid = a.attrelid AND d.adnum = a.attnum 和 a.atthasdef)a.attnotnull, a.attnum, pg_catalog.pg_get_indexdef (a.attrelid,a.attnum,TRUE) AS indexdef FROM pg_catalog.pg_attribute 一个 WHERE a.attrelid = (SELECT oid FROM pg_class WHERE relname = 'index_name') AND a.attnum > 0 而不是 a.attisdropped 由 a.attnum 订购;
于 2011-03-20T21:47:51.017 回答
0
接受的答案对我不起作用(执行时发生错误)。
无论如何,您可以列出数据库中的所有列并以某种方式标记所有索引列(限制结果行集的能力被称为注释):
WITH
table_select as (
select row_number() over(ORDER BY relname) as rownum,
c.relname, c.oid, c.reltuples
FROM pg_class c
JOIN pg_namespace n ON (n.oid = c.relnamespace)
WHERE c.relkind = 'r'::"char"
--AND n.nspname = '%MyNameSpaceHere%'
ORDER BY c.relname
),
indxs as (
select distinct t.relname as table_name, a.attname as column_name
from pg_class t, pg_class i, pg_index ix, pg_attribute a
where
t.oid = ix.indrelid
and i.oid = ix.indexrelid
and a.attrelid = t.oid
and a.attnum = ANY(ix.indkey)
and t.relkind = 'r'
--and t.relname like 'mytable here'
and cast (i.oid::regclass as text) like '%MyNameSpaceHere%'
order by
t.relname --, i.relname
),
cols as (
select a.attname, a.attrelid, c.oid, col.TABLE_NAME, col.COLUMN_NAME
FROM table_select c
JOIN pg_attribute a ON (a.attrelid = c.oid) AND (a.attname <> 'tableoid')
LEFT JOIN information_schema.columns col ON
(col.TABLE_NAME = c.relname AND col.COLUMN_NAME = a.attname )
WHERE
( a.attnum >= 0 ) --attnum > 0 for real columns
)
--select * from table_select t
select c.TABLE_NAME, c.COLUMN_NAME,
case when i.column_name is not null then 'Y' else '' end as is_indexed
from cols c
left join indxs i on (i.table_name = c.table_name and i.column_name = c.column_name)
示例结果:
table_name column_name is_indexed
'events id "Y"
events type "Y"
events descr "" '
于 2013-05-24T12:52:35.730 回答