postgresql 常用SQL语句小结

 更新时间:2022年11月15日 22:51:12   投稿:mdxy-dxy  
postgresql使用过程中常用到的一些sql语句,方便我们快速使用查询一些操作特整理一下,方便需要的朋友

1、查询链接数

SELECT sum(numbackends) FROM pg_stat_database;

2、查看死锁状态

select pid,
       usename,
       pg_blocking_pids(pid) as blocked_by,
       query as blocked_query
from pg_stat_activity
where cardinality(pg_blocking_pids(pid)) > 0;

3、删除死锁进程

SELECT pg_cancel_backend(__pid__);
SELECT pg_terminate_backend(__pid__);

4、备份数据库

# sql文件
pg_dump dangerousdb > db.sql
# tar文件
pg_dump -U postgres -F c dangerousdb > dangerousdb.tar
# gz文件
pg_dump -U postgres dangerousdb | gzip > dangerousdb.gz

5、还原数据库

# 已经存在数据库
pg_restore -U postgres -Ft -d dbcooper < dbcooper.tar
# 创建新数据库
pg_restore -U postgres -Ft -C -d dbcooper < dbcooper.tar
#   

6、插入数据

插入单条数据

INSERT INTO TABLE_1
(
column_1,
column_2,
column_3
)
values(
column_1,
column_2,
column_3
)

插入多条数据

INSERT INTO TABLE_1
(
column_1,
column_2,
column_3
)
values(
column_1,
column_2,
column_3
),(
column_1,
column_2,
column_3
)...

从一张表查询到的数据插入到另一张表

INSERT INTO TABLE_1
(
column_1,
column_2,
column_3
)
SELECT
column_1,
column_2,
column_3
FROM
TABLE_2
where TABLE_2条件;

7 、查询pg中单张表的大小(不包含索引)

select
    pg_size_pretty(pg_relation_size('schema.table_name'));

8、查询数据库中所有表的大小

select
    relname,
    pg_size_pretty(pg_relation_size(relid))
from
    pg_stat_user_tables
where
    schemaname = 'public'
order by
    pg_relation_size(relid) desc;

9、按顺序查看索引

select
    indexrelname,
    pg_size_pretty(pg_relation_size(relid))
from
    pg_stat_user_indexes
where
    schemaname = 'public'
order by
    pg_relation_size(relid) desc;

10 、查询数据库的大小

select
    pg_database.datname,
    pg_size_pretty (pg_database_size(pg_database.datname)) as size
from
    pg_database;

11、查询被锁定的表

select
    pg_class.relname as table,
    pg_database.datname as database,
    pid,
    mode,
    granted
from
    pg_locks,
    pg_class,
    pg_database
where
    pg_locks.relation = pg_class.oid
    and pg_locks.database = pg_database.oid;

12 、查询一个Schema下面的所有表的总大小(单位MB,包括索引和数据)

select
    schemaname ,
    round(sum(pg_total_relation_size(schemaname || '.' || tablename))/ 1024 / 1024) "Size_MB"
from
    pg_tables
where
    schemaname = '<schemaname>'
group by
    1;

13 、查询所有表的大小并排序(包含索引)

select
    table_schema || '.' || table_name as table_full_name,
    pg_size_pretty(pg_total_relation_size('"' || table_schema || '"."' || table_name || '"')) as size
from
    information_schema.tables
order by
    pg_total_relation_size('"' || table_schema || '"."' || table_name || '"') desc
limit 20;

14 、查询表大小按大小排序并分离data与index

select
    table_name,
    pg_size_pretty(table_size) as table_size,
    pg_size_pretty(indexes_size) as indexes_size,
    pg_size_pretty(total_size) as total_size
from
    (
    select
        table_name,
        pg_table_size(table_name) as table_size,
        pg_indexes_size(table_name) as indexes_size,
        pg_total_relation_size(table_name) as total_size
    from
        (
        select
            ('"' || table_schema || '"."' || table_name || '"') as table_name
        from
            information_schema.tables) as all_tables
    order by
        total_size desc) as pretty_sizes;

或者

select
    table_name,
    pg_size_pretty(table_size) as table_size,
    pg_size_pretty(indexes_size) as indexes_size,
    pg_size_pretty(total_size) as total_size
from
    (
    select
        table_name,
        pg_table_size(table_name) as table_size,
        pg_indexes_size(table_name) as indexes_size,
        pg_total_relation_size(table_name) as total_size
    from
        (
        select
            ('' || table_schema || '.' || table_name || '') as table_name
        from
            information_schema.tables) as all_tables
    order by
        total_size desc) as pretty_sizes;

到此这篇关于postgresql 常用SQL语句小结的文章就介绍到这了,更多相关postgresql 常用SQL内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • PostgreSQL Sequence序列的使用详解

    PostgreSQL Sequence序列的使用详解

    这篇文章主要介绍了PostgreSQL Sequence序列的使用详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • postgresql SQL语句变量的使用说明

    postgresql SQL语句变量的使用说明

    这篇文章主要介绍了postgresql SQL语句变量的使用说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • PgSQL条件语句与循环语句示例代码详解

    PgSQL条件语句与循环语句示例代码详解

    这篇文章主要介绍了PgSQL条件语句与循环语句,pgSQL中有两种条件语句分别为if与case语句,每种语句通过示例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-07-07
  • postgresql如何兼容MySQL if函数

    postgresql如何兼容MySQL if函数

    这篇文章主要介绍了postgresql如何兼容MySQL if函数问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • PostgreSQL长事务概念解析

    PostgreSQL长事务概念解析

    pg中的长事务会影响表中垃圾回收,导致表的年龄增长无法freeze。能消耗事务的只有当执行了一些DML或者DDL操作后才能算是我们通常说的长事务。否则只能算是我们常说的长连接,当然长连接也有很多弊端,例如占用内存、cpu等资源
    2022-09-09
  • postgresql流复制原理以及流复制和逻辑复制的区别说明

    postgresql流复制原理以及流复制和逻辑复制的区别说明

    这篇文章主要介绍了postgresql流复制原理以及流复制和逻辑复制的区别说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • PostgreSQL自定义函数并且调用方式

    PostgreSQL自定义函数并且调用方式

    这篇文章主要介绍了PostgreSQL如何自定义函数并且调用,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-06-06
  • PostgreSQL 存储过程的进阶讲解(含游标、错误处理、自定义函数、事务)

    PostgreSQL 存储过程的进阶讲解(含游标、错误处理、自定义函数、事务)

    PL/pgSQL 游标允许我们封装一个查询,然后每次处理结果集中的一条记录,这篇文章主要介绍了PostgreSQL 存储过程的进阶介绍(含游标、错误处理、自定义函数、事务),需要的朋友可以参考下
    2023-03-03
  • PostgreSQL使用jsonb进行数组增删改查的操作详解

    PostgreSQL使用jsonb进行数组增删改查的操作详解

    有时候我们需要使用PostgreSQL这种结构化数据库来存储一些非结构化数据,PostgreSQL恰好又提供了json这种数据类型,这里我们来简单介绍使用jsonb的一些常见操作,需要的朋友可以参考下
    2024-03-03
  • postgresql 实现将字段为空的值替换为指定值

    postgresql 实现将字段为空的值替换为指定值

    这篇文章主要介绍了postgresql 实现将字段为空的值替换为指定值,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01

最新评论