在postgres中显示所有不是空表

时间:2014-07-14 10:28:16

标签: sql postgresql

是否有简单的PostgreSQL甚至SQL方式列出空/非空表?

P.S .: 我正在分析一个包含数百个表的数据库,并希望检测死亡代码"。 我假设,当一个月后的桌子仍然是空的,而不是它没有使用。

修改:解决

谢谢大家! 最后,这句话似乎输出了我可以使用的统计数据:

select schemaname, relname, n_tup_ins from pg_stat_all_tables WHERE schemaname = 'public' ORDER BY n_tup_ins 

4 个答案:

答案 0 :(得分:6)

您可以使用PostgreSQL的系统目录,例如

SELECT n.nspname, c.relname
FROM pg_class c
INNER JOIN pg_namespace n ON (n.oid = c.relnamespace)
WHERE c.reltuples = 0 AND c.relkind = 'r';

根据文档,行数是一个估计值。

如果您的表中的列具有序列中的默认值,您可以列出它们并使用nextval检查它们的值。 (遗憾的是,currval会返回与会话相关的值,因此您必须确保没有其他人在使用该数据库,并同时使用nextvalsetval。)

SELECT n.nspname, c.relname
FROM pg_class c
INNER JOIN pg_namespace n ON (n.oid = c.relnamespace)
WHERE c.relkind = 'S';

(不幸的是我还没有找到任何方法来确定哪个序列属于哪个表。显然它会非常有用。无论如何,你可以使用pg_class.relnamespace来缩小结果范围。)

有关详细信息,请参阅http://www.postgresql.org/docs/9.3/interactive/catalogs-overview.html

答案 1 :(得分:5)

检查行数可能给你错误的结果。假设一个表用作临时表:行插入(例如从平面文件中),处理和删除。如果您检查该表中的行数,您可能会相信,如果您在处理过程中没有碰巧运行查询,那么它就永远不会被使用。

检测"未使用"的另一种方法表将监视IO和对表执行的更改。

统计视图pg_stat_user_tables记录系统中每个表的更改(删除,插入,更新)。统计视图pg_statio_user_tables记录针对表执行的IO。

如果以固定间隔拍摄这些表的快照,则可以计算值的差异,并查看是否使用了表。

您可以使用pg_stat_reset()将所有值重置为零,然后从该值开始。

答案 2 :(得分:3)

你可以这样做

CREATE OR REPLACE FUNCTION fn_table()
  RETURNS TABLE(name text,count int) AS
$BODY$
DECLARE
    data record;
    v_sql text;
BEGIN
    DROP TABLE IF EXISTS demo;
    CREATE TEMP TABLE demo (name text,count int);
    FOR data in (SELECT table_name FROM INFORMATION_SCHEMA.tables WHERE table_schema = 'public')    LOOP
        v_sql := 'INSERT INTO demo SELECT '''||data.table_name||''', COUNT(*) FROM '||data.table_name;
        RAISE INFO 'v_sql:%',v_sql;
        EXECUTE v_sql;
    END LOOP;
    RETURN QUERY (SELECT * FROM demo);
END
$BODY$
  LANGUAGE plpgsql VOLATILE
  COST 100;

输出:

"child";0
"location_master";6
"location";5
"tmp";5
"a1";7
"b1";3
"master";0
"child2";0
"child1";0

这里child,master,child1,child2有0个计数,表示它们是空表。

答案 3 :(得分:-2)

请尝试一次,希望它可以帮助您:

Running the query below will give you a list of tables and indexes that have not been used since SQL Server was last restarted. Once you have a list of tables, you can do a dependency check to get a list of stored procedures that use each table. Then you can search your C# source code for thos SPs and table names.



-- Unused tables & indexes. Tables have index_id’s of either 0 = Heap table or 1 = Clustered Index

SELECT OBJECTNAME = OBJECT_NAME(I.OBJECT_ID), INDEXNAME = I.NAME, I.INDEX_ID

FROM SYS.INDEXES AS I

INNER JOIN SYS.OBJECTS AS O

ON I.OBJECT_ID = O.OBJECT_ID

WHERE OBJECTPROPERTY(O.OBJECT_ID,'IsUserTable') = 1

AND I.INDEX_ID

NOT IN (SELECT S.INDEX_ID

FROM SYS.DM_DB_INDEX_USAGE_STATS AS S

WHERE S.OBJECT_ID = I.OBJECT_ID

AND I.INDEX_ID = S.INDEX_ID

AND DATABASE_ID = DB_ID(db_name()))

ORDER BY OBJECTNAME, I.INDEX_ID, INDEXNAME ASC