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

 更新时间:2023年03月01日 10:09:14   作者:黄宝康  
这篇文章主要介绍了如何查看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 行记录)

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;

总结

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

相关文章

  • PostgreSQL LIKE 大小写实例

    PostgreSQL LIKE 大小写实例

    这篇文章主要介绍了PostgreSQL LIKE 大小写实例,具有很好的参考价值,希望对大家有所帮助。 一起跟随小编过来看看吧
    2021-01-01
  • 详解如何优化在PostgreSQL中对于日期范围的查询

    详解如何优化在PostgreSQL中对于日期范围的查询

    在 PostgreSQL 中,处理日期范围的查询是常见的操作,然而,如果不进行适当的优化,这些查询可能会导致性能问题,特别是在处理大型数据集时,本文章将详细讨论如何优化在 PostgreSQL 中对于日期范围的查询,需要的朋友可以参考下
    2024-07-07
  • Postgresql 默认用户名与密码的操作

    Postgresql 默认用户名与密码的操作

    这篇文章主要介绍了Postgresql 默认用户名与密码的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • PostgreSQL教程(二十):PL/pgSQL过程语言

    PostgreSQL教程(二十):PL/pgSQL过程语言

    这篇文章主要介绍了PostgreSQL教程(二十):PL/pgSQL过程语言,本文讲解了、PL/pgSQL概述、PL/pgSQL的结构、声明、基本语句、控制结构等内容,需要的朋友可以参考下
    2015-05-05
  • PostgreSQL完成按月累加的操作

    PostgreSQL完成按月累加的操作

    这篇文章主要介绍了PostgreSQL完成按月累加的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • PostgreSQL备份和还原命令整理大全

    PostgreSQL备份和还原命令整理大全

    这篇文章主要给大家介绍了关于PostgreSQL备份和还原命令整理的相关资料,PostgreSQL是一款非常强大的开源数据库系统,提供种类繁多的备份选项,包括完全备份、增量备份等,需要的朋友可以参考下
    2023-07-07
  • 如何在PostgreSQL中创建只读权限和读写权限的账号

    如何在PostgreSQL中创建只读权限和读写权限的账号

    一个良好的账号管理策略对于数据库的安全和数据的完整性至关重要,通过为不同的用户设置适当的权限,可以确保他们只能访问他们需要的数据,并防止对敏感数据的意外或恶意访问,本文介绍在 PostgreSQL中创建只读权限和读写权限的账号的步骤和方法,感兴趣的朋友一起看看吧
    2023-08-08
  • PostgreSQL设置主键从1开始自增的详细步骤

    PostgreSQL设置主键从1开始自增的详细步骤

    和MySQL不同,在 PostgreSQL 中,设置主键从1开始自增并重新开始自增是通过序列(sequence)来实现的,本文给大家分享PostgreSQL设置主键从1开始自增的详细步骤,感兴趣的朋友一起看看吧
    2023-11-11
  • PostgreSQL数据库实现公网远程连接的操作步骤

    PostgreSQL数据库实现公网远程连接的操作步骤

    PostgreSQL是一个功能非常强大的关系型数据库管理系统(RDBMS),本文呢将简单几步通过cpolar 内网穿透工具即可现实本地postgreSQL 远程访问,需要的朋友可以参考下
    2023-09-09
  • PostgreSQL处理数据并发更新冲突的解决方法

    PostgreSQL处理数据并发更新冲突的解决方法

    在数据库并发操作环境中,多个事务同时尝试更新相同的数据可能导致冲突,PostgreSQL 提供了一系列机制来处理这些并发更新冲突,以确保数据的一致性和完整性,所以本文给大家介绍了PostgreSQL处理数据并发更新冲突的解决方法,需要的朋友可以参考下
    2024-07-07

最新评论