Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/67.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
列出postgresql数据库中所有表的表大小_Sql_Postgresql - Fatal编程技术网

列出postgresql数据库中所有表的表大小

列出postgresql数据库中所有表的表大小,sql,postgresql,Sql,Postgresql,我可以通过以下方式获得postgresql数据库中所有表中的列数 SELECT TABLE_SCHEMA, TABLE_NAME, COUNT(*) FROM INFORMATION_SCHEMA.COLUMNS GROUP BY TABLE_SCHEMA, TABLE_NAME; SELECT COUNT(*) FROM mytable 我可以通过 SELECT TABLE_SCHEMA, TABLE_NAME, COUNT(*) FROM INFORMATION_SCHEMA.C

我可以通过以下方式获得postgresql数据库中所有表中的列数

SELECT TABLE_SCHEMA, TABLE_NAME, COUNT(*) 
FROM INFORMATION_SCHEMA.COLUMNS 
GROUP BY TABLE_SCHEMA, TABLE_NAME;
SELECT  COUNT(*) FROM mytable
我可以通过

SELECT TABLE_SCHEMA, TABLE_NAME, COUNT(*) 
FROM INFORMATION_SCHEMA.COLUMNS 
GROUP BY TABLE_SCHEMA, TABLE_NAME;
SELECT  COUNT(*) FROM mytable

如何在一个查询中获取数据库中所有表的列数和行数?

使用a组合查询并将其与一个连接起来,如建议使用名称为的@a_horse_,例如

WITH j AS (
  SELECT table_schema, table_name, count(*) AS count_columns
  FROM information_schema.columns
  GROUP BY table_schema, table_name
) 
SELECT 
  nspname AS schemaname,relname,reltuples,count_columns
FROM pg_class C
LEFT JOIN pg_namespace N ON (N.oid = C.relnamespace)
JOIN j ON j.table_name = relname AND j.table_schema = nspname 
WHERE 
  nspname NOT IN ('pg_catalog', 'information_schema') AND
  relkind='r' 
ORDER BY reltuples DESC;

您可以在命令行中使用psql在所选数据库中输入\d+,也可以在此处使用SQL语句:


鉴于Oracle不支持
信息\u SCHEMA.COLUMNS
,您的问题值得怀疑。请用您真正使用的数据库进行标记。@a_horse_和_no_name我在该页上找不到答案,即如何在一次获得行数和列数。所有这些答案将为您提供每个表的行数。它们可以很容易地扩展到包含列计数(特别是)“简单扩展”实际上是我最初的问题,谢谢!