是否有简单的PostgreSQL甚至SQL方式列出空/非空表?
P.S .: 我正在分析一个包含数百个表的数据库,并希望检测死亡代码"。 我假设,当一个月后的桌子仍然是空的,而不是它没有使用。
修改:解决
谢谢大家! 最后,这句话似乎输出了我可以使用的统计数据:
select schemaname, relname, n_tup_ins from pg_stat_all_tables WHERE schemaname = 'public' ORDER BY n_tup_ins
答案 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
会返回与会话相关的值,因此您必须确保没有其他人在使用该数据库,并同时使用nextval
和setval
。)
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