文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何查看PostgreSQL数据库中所有表

2023-03-01 09:57

关注

查看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 行记录)

PostgreSQL数据库表空间,索引,表大小查询

Postgresql 数据库

一: 查询表空间大小

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;

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯