本文小编为大家详细介绍“怎么查看PostgreSQL数据库中所有表”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么查看PostgreSQL数据库中所有表”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
作为曾经干过运维的我来说,或许对大部分运维人员来说,不能依靠管理工具来操作数据库,如pgAdmin,经常远程登录到某一台数据库服务器,使用命令行的方式查询数据库中的表。
获取当前db中所有的表信息。
select * from pg_tables;
用户自定义的表,如果未经特殊处理,默认都是放在名为public的schema下
select tablename from pg_tables where schemaname='public'
postgres=# select tablename from pg_tables where schemaname='public'; tablename ----------- tb_test (1 行记录)
想要进一步查看表结构,可以使用\d 表名
postgres=# \d tb_test; 数据表 "public.tb_test" 栏位 | 类型 | Collation | Nullable | Default ------+----------------+-----------+----------+--------- id | integer | | | name | character(100) | | |
而且如果不是大批量的进行CRUD,直接在命令行中操作也是锻炼你的语法水平的时候
postgres=# insert into tb_test(id,name) values(1,'huangbaokang'); INSERT 0 1 postgres=# select * from tb_test; id | name ----+----------------------------------------------------------------- --------------------------- 1 | huangbaokang (1 行记录)
一: 查询表空间大小
select pg_size_pretty(pg_tablespace_size('pg_default'));
二: 查询所有数据库大小
select pg_database.datname, pg_size_pretty(pg_database_size(pg_database.datname)) AS size from pg_databas;
三: 查询指定索引大小
select pg_size_pretty(pg_relation_size('索引字段名'));
四: 查询指定表所有索引大小
select pg_size_pretty(pg_indexes_size('表名'));
五: 查询指定模式里所有的索引大小,按从大到小的顺序排列
select relname,indexrelname, pg_size_pretty(pg_relation_size(relid)) from pg_stat_user_indexes where schemaname='模式名' order by pg_relation_size(relid) desc;
六: 查询指定表大小(仅仅指定表数据)
select pg_size_pretty(pg_relation_size('表名'));
七: 查询指定表总大小(包括表数据与索引)
select pg_size_pretty(pg_total_relation_size('表名'));
八: 查询指定模式里面所有表大小(仅仅指定表数据,从大到小)
select relname, pg_size_pretty(pg_relation_size(relid)) from pg_stat_user_tables where schemaname='模式名' order by pg_relation_size(relid) desc;
九:查询指定schema里面所有表数据大小,总索引大小,总大小,行数
SELECT table_size.relname 表名, pg_size_pretty ( pg_relation_size ( relid ) ) 表数据大小, pg_size_pretty ( pg_indexes_size ( relid ) ) 表总索引大小, pg_size_pretty ( pg_total_relation_size ( relid ) ) 表总大小, 表行数 FROM pg_stat_user_tables table_size LEFT JOIN ( SELECT relname, reltuples :: DECIMAL ( 19, 0 ) 表行数 FROM pg_class r JOIN pg_namespace n ON ( relnamespace = n.oid ) WHERE relkind = 'r' AND n.nspname = '模式名' ) table_num ON table_num.relname = table_size.relname WHERE schemaname = '模式名' ORDER BY pg_relation_size ( relid ) DESC;
读到这里,这篇“怎么查看PostgreSQL数据库中所有表”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。