PostgreSQL中的psql命令详解

 更新时间:2023年07月27日 11:13:24   作者:孙霸天  
psql是PostgreSQL的一个命令行交互式客户端工具,它具有非常丰富的功能,类似于Oracle的命令行工具sqlplus,这篇文章主要介绍了PostgreSQL-psql命令详解,需要的朋友可以参考下

psql命令

psql是PostgreSQL的一个命令行交互式客户端工具,它具有非常丰富的功能,类似于Oracle的命令行工具sqlplus。

元命令

连接数据库

连接指定服务器上的数据库

psql -h 192.168.1.210 -p 5432 -U hr -d hr_db
  • -h后面的IP地址(192.168.1.210)是数据库所在的IP地址
  • -p后面的端口(5432)是数据库的监听端口
  • -U后面的参数(hr)是创建的用户名
  • -d后面的参数(hr_db)是创建的数据库名称

断开psql客户端

# 按Ctrl+D组合键
\q

常用命令

"\c"命令

# 查看所有数据库
\l
# 切换数据库
\c gis

image-20220519145705362

"\d"命令

# 查看当前数据库中所有表、视图、序列
\d
# 在"\d"命令后面接表名,则可以查看该表的表定义
\d pgbench_accounts

image-20220519145735955

"\db"命令

# 查看表空间的信息
\db

image-20220519144957193

"\dn"命令

# 可以查看所有的模式信息
\dn

image-20220519145431618

“\du"命令或”\dg"命令

# 可以查看数据库中的所有角色或用户
\du

image-20220519145954157

"\x"命令

# 可以设置查询结果的输出模式
\x

image-20220519150755522

"?"命令

# 可以查询PostgreSQL支持的所有命令
\?

image-20220519150928575

其他常用命令

# 查看数据库
\l 
# 查看表定义
\d tablename
# 查看表大小
\dt+ tablename
# 查看索引大小
\di+ tablename
# 查看函数代码 \sf random_range
\sf functionName
\sf functionName(integer,integer)
# 查看SQL命令语法
\h 
\h create database
# 显示SQL语句执行时间,(再执行一次关闭)
\timing

使用技巧

获取元命令对应的SQL代码

psql执行元命令,实质上是转换成对应的SQL语句来执行的。如果要获取这些SQL语句,则需要在psql连接数据库时增加“-E”选项

psql -h 127.0.0.1 -p 5432 -U postgres -d postgres -E 

image-20220519152214339

使用上下键翻动历史命令

psql支持使用上下键获取执行过的历史命令

自动补全功能

psql的自动补全功能使用起来非常方便。在执行语句时,不需要完全输入数据对象的名称,使用Tab键可以自动补全

显示SQL语句执行时间

使用“\timing”命令,可以打开显示SQL语句执行时间的开关。再使用一次“\timing”命令,则关掉该开关

image-20220519152749781

日常维护语句

查询活动会话(active_session)

select pid,usename,datname,query,client_addr from pg_stat_activity where pid <> pg_backend_pid() and state='active' order by query;

image-20220519152857575

查询等待事件(wait_event)

select wait_event_type,wait_event,state,query,a.* from pg_stat_activity a where query like 'insert%';

image-20220519153320862

到此这篇关于PostgreSQL-psql命令详解的文章就介绍到这了,更多相关PostgreSQL psql命令内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • PostgreSQL function返回多行的操作

    PostgreSQL function返回多行的操作

    这篇文章主要介绍了PostgreSQL function返回多行的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • PostgreSQL11修改wal-segsize的操作

    PostgreSQL11修改wal-segsize的操作

    这篇文章主要介绍了PostgreSQL11修改wal-segsize的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • postgresql如何找到表中重复数据的行并删除

    postgresql如何找到表中重复数据的行并删除

    这篇文章主要介绍了postgresql如何找到表中重复数据的行并删除问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • PostgreSQL 10分区表及性能测试报告小结

    PostgreSQL 10分区表及性能测试报告小结

    PostgreSQL的分区表跟先前版本一样,也要先建立主表,然后再建立子表,使用继承的特性,但不需要手工写规则了,目前支持range、list分区,10正式版本发布时不知会不会支持其它方法,感兴趣的朋友跟随小编一起看看吧
    2022-01-01
  • postgresql 性能参数配置方式

    postgresql 性能参数配置方式

    这篇文章主要介绍了postgresql 性能参数配置方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • postgresql兼容MySQL on update current_timestamp问题

    postgresql兼容MySQL on update current_timestamp

    这篇文章主要介绍了postgresql兼容MySQL on update current_timestamp问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • Windows下PostgreSQL安装图解

    Windows下PostgreSQL安装图解

    这篇文章主要为大家介绍了如果在Windows下安装PostgreSQL数据库的方法,需要的朋友可以参考下
    2013-11-11
  • 教你如何在Centos8-stream安装PostgreSQL13

    教你如何在Centos8-stream安装PostgreSQL13

    这篇文章主要介绍了Centos8-stream安装PostgreSQL13,初始化PostgreSQL需要先创建postgresql储存目录,启动postgresql数据库,本文给大家介绍的非常详细,需要的朋友可以参考下
    2022-02-02
  • Postgresql删除数据库表中重复数据的几种方法详解

    Postgresql删除数据库表中重复数据的几种方法详解

    本文详细讲解了Postgresql删除数据库表中重复数据的几种方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-10-10
  • PostgreSQL如何查询表大小(单独查询和批量查询)

    PostgreSQL如何查询表大小(单独查询和批量查询)

    PostgreSQL提供了多个系统管理函数来查看表,索引表空间及数据库的大小,这篇文章主要给大家介绍了关于PostgreSQL如何查询表大小的相关资料,文中介绍的方法包括单独查询和批量查询,需要的朋友可以参考下
    2024-02-02

最新评论