postgresql的psql常用命令-4

时间:2023-02-15 08:18:36

psql是PostgreSQL的一个命令行交互式客户端工具

1. 查看postgresql账号
[root@localhost ~]#cat /etc/passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
postgres:x:26:26:PostgreSQL Server:/var/lib/pgsql:/bin/bash

2.登陆
[root@localhost ~]# su - postgres
-bash-4.1$ psql #连接到数据库服务器,可以在其中输入相应的SQL语句或者psql的命令,psql的命令都以\开始
psql (9.6.3)
Type "help" for help.

3.查看帮助
postgres=# \? #可以看到所有的psql的可执行命令,**请注意该命令显示的是psql客户端能够使用的命令**
General
\copyright 显示 PostgreSQL 的使用和发行条款
\errverbose 尽可能的显示所有当前的错误信息
\g [FILE] or ; 执行查询命令 (并且把结果输出到文件或者管道|)
\gexec 执行查询命令, 然后在结果中显示执行完成的所有的值
\gset [PREFIX] 执行查询命令并把结果存储在psql变量中
\q 退出psql
\crosstabview [COLUMNS] 执行插叙命令并把结果显示在交叉表中
\watch [SEC] 每SEC秒执行查询命令

Help
\? [commands] 显示反斜杠命令的帮助
\? options 显示在psql命令行选项的帮助
\? variables 显示某个变量的帮助
\h [NAME] SQL 命令语法上的说明,用 * 显示全部命令

Query Buffer
\e [FILE] [LINE] edit the query buffer (or file) with external editor
\ef [FUNCNAME [LINE]] edit function definition with external editor
\ev [VIEWNAME [LINE]] edit view definition with external editor
\p show the contents of the query buffer
\r reset (clear) the query buffer
\s [FILE] display history or save it to file
\w FILE 将查询缓存区写入档案

Input/Output
\copy ... 执行 SQL COPY,数据流指向客户端主机
\echo [STRING] 将字符串写到标准输出流
\i FILE 从文件中执行命令
\ir FILE 与\i一样, 但是相对于当前脚本的位置
\o [FILE] 把所有查询结果输出到文件或者管道|
\qecho [STRING] 把字符串写到查询输出流 (see \o)

Informational
(options: S = show system objects, + = additional detail)
\d[S+] 显示所有的 tables, views, and sequences
\d[S+] NAME 显示指定名字的 table, view, sequence, or index 的表结构
\da[S] [PATTERN] 显示所有聚合函数
\dA[+] [PATTERN] 显示所有访问方法
\db[+] [PATTERN] 显示所有表空间
\dc[S+] [PATTERN] 显示字元编码转换
\dC[+] [PATTERN] 显示所有型别转换
\dd[S] [PATTERN] 显示所有物件的注解
\ddp [PATTERN] 显示所有默认权限
\dD[S+] [PATTERN] 显示所有共同值域
\det[+] [PATTERN] 显示所有外部表
\des[+] [PATTERN] 显示所有远程服务器
\deu[+] [PATTERN] 显示所有远程服务器用户
\dew[+] [PATTERN] 显示所有外部数据包装器
\df[antw][S+] [PATRN] 显示 [only agg/normal/trigger/window] 函数
\dF[+] [PATTERN] 显示所有文本搜索配置
\dFd[+] [PATTERN] 显示所有文本搜索字典
\dFp[+] [PATTERN] 显示所有文本搜索解析器
\dFt[+] [PATTERN] 显示所有文本搜索模板
\dg[S+] [PATTERN] 显示所有角色
\di[S+] [PATTERN] 显示所有索引
\dl 显示所有大对象, 与 \lo_list 类似
\dL[S+] [PATTERN] 显示所有程序语言
\dm[S+] [PATTERN] 显示所有具体视图
\dn[S+] [PATTERN] 显示所有模式
\do[S] [PATTERN] 显示所有操作符
\dO[S+] [PATTERN] 显示所有排序规则
\dp [PATTERN] 显示所有表 视图 序列 的访问权限
\drds [PATRN1 [PATRN2]] 显示每个数据库的角色设置
\ds[S+] [PATTERN] 显示所有序列
\dt[S+] [PATTERN] 显示所有表
\dT[S+] [PATTERN] 显示所有数据类型
\du[S+] [PATTERN] 显示所有角色
\dv[S+] [PATTERN] 显示视图
\dE[S+] [PATTERN] 显示所有外部表
\dx[+] [PATTERN] 显示所有扩展
\dy [PATTERN] 显示所有事件触发器
\l[+] [PATTERN] #列出所有的数据库
\sf[+] FUNCNAME 显示函数的定义
\sv[+] VIEWNAME 显示视图的定义
\z [PATTERN] 与\dp一样

Formatting
\a 切换不对齐和对齐的输出模式
\C [STRING] 设置表头,或者如果是none则不设置
\f [STRING] 显示或者设置未对齐输出的字段分隔符
\H 切换HTML输出模式(默认是off)
\pset [NAME [VALUE]] 设置表的输出选项
(NAME := {format|border|expanded|fieldsep|fieldsep_zero|footer|null|
numericlocale|recordsep|recordsep_zero|tuples_only|title|tableattr|pager|
unicode_border_linestyle|unicode_column_linestyle|unicode_header_linestyle})
\t [on|off] 只显示行 (当前off)
\T [STRING] 设置HTML <table> 标签的属性, 或者如果是none则不设置
\x [on|off|auto] 切换扩展输出 (当前默认 off)

Connection
\c[onnect] {[DBNAME|- USER|- HOST|- PORT|-] | conninfo} 连线到新的资料库 (目前是 "test")

\encoding [ENCODING] 显示或设定用户端字元编码
\password [USERNAME] 修改用户密码
\conninfo 显示当前的连接信息

Operating System
\cd [DIR] 改变目前的工作目录
\setenv NAME [VALUE] 设置或者取消环境变量
\timing [on|off] 切换命令计时开关 (默认是off)
\! [COMMAND] 执行shell命令 or 打开内部 shell命令

Variables
\prompt [TEXT] NAME 提示用户设置内部变量
\set [NAME [VALUE]] 设置内部变量, 假如没有参数则显示所有参数
\unset NAME 取消(删除)内部变量

Large Objects
\lo_export LOBOID FILE
\lo_import FILE [COMMENT]
\lo_list
\lo_unlink LOBOID 大对象的操作


4.一些常用命令使用举例

(1)psql加上-E参数,可以把psql中各种以"\"开头的命令执行的实际SQL打印出来
-sh-4.1$ psql -E -h /var/opt/gitlab/postgresql -d gitlabhq_production
psql (9.2.18)
Type "help" for help.

gitlabhq_production=# \d
********* QUERY **********
SELECT n.nspname as "Schema",
c.relname as "Name",
CASE c.relkind WHEN 'r' THEN 'table' WHEN 'v' THEN 'view' WHEN 'i' THEN 'index' WHEN 'S' THEN 'sequence' WHEN 's' THEN 'special' WHEN 'f' THEN 'foreign table' END as "Type",
pg_catalog.pg_get_userbyid(c.relowner) as "Owner"
FROM pg_catalog.pg_class c
LEFT JOIN pg_catalog.pg_namespace n ON n.oid = c.relnamespace
WHERE c.relkind IN ('r','v','S','f','')
AND n.nspname <> 'pg_catalog'
AND n.nspname <> 'information_schema'
AND n.nspname !~ '^pg_toast'
AND pg_catalog.pg_table_is_visible(c.oid)
ORDER BY 1,2;

如果你在使用之后,想立即关闭
postgres=# \set ECHO_HIDDEN off
postgres=# \d
No relations found.

(2)显示所有表
gitlabhq_production=# \d
List of relations
Schema | Name | Type | Owner
--------+---------------------------------------------+----------+--------
public | abuse_reports | table | gitlab
public | abuse_reports_id_seq | sequence | gitlab

(3)\d后面跟一个表名,表示显示这个表的结构定义
gitlabhq_production=# \d abuse_reports
Table "public.abuse_reports"
Column | Type | Modifiers
--------------+-----------------------------+------------------------------------------------------------
id | integer | not null default nextval('abuse_reports_id_seq'::regclass)
reporter_id | integer |
user_id | integer |
message | text |
created_at | timestamp without time zone |
updated_at | timestamp without time zone |
message_html | text |
Indexes:
"abuse_reports_pkey" PRIMARY KEY, btree (id)

(4)\d后面可以跟一通配符"*"或"?"
gitlabhq_production=# \d a*
Table "public.abuse_reports"
Column | Type

| Modifiers
--------------+-----------------------------+------------------------------------------------------------
id | integer | not null default nextval('abuse_reports_id_seq'::regclass)
reporter_id | integer |
user_id | integer |
message | text |
created_at | timestamp without time zone |
updated_at | timestamp without time zone |
message_html | text |
Indexes:
"abuse_reports_pkey" PRIMARY KEY, btree (id)

(5)\d+命令,该命令将显示比\d命令更详细的信息
gitlabhq_production=# \d+
List of relations
Schema | Name | Type | Owner | Size | Description
--------+---------------------------------------------+----------+--------+------------+-------------
public | abuse_reports | table | gitlab | 8192 bytes |
public | abuse_reports_id_seq | sequence | gitlab | 8192 bytes |
public | appearances | table | gitlab | 8192 bytes |

(6)显示所有表空间
gitlabhq_production=# \db
List of tablespaces
Name | Owner | Location
------------+-------------+----------
pg_default | gitlab-psql |
pg_global | gitlab-psql |
(2 rows)

(7)匹配不同对象类型的\d命令
只显示匹配的表,可以使用\dt命令
只显示索引,可以使用\di命令
只显示序号,可以使用\ds命令
只显示视图,可以使用\dv命令
只显示函数,可以使用\df命令

(8)想显示SQL已执行的时间,可以用\timing命令
gitlabhq_production=# \timing on
Timing is on.
sample_db=# select count(*) from abuse_reports;
count
-------
69
(69 row)

Time: 3.48 ms

(9)显示所有用户或者角色
gitlabhq_production=# \du
List of roles
Role name | Attributes | Member of
-------------------+------------------------------------------------+-----------
gitlab | | {}
gitlab-psql | Superuser, Create role, Create DB, Replication | {}
gitlab_replicator | Replication | {}

gitlabhq_production=# \dg
List of roles
Role name | Attributes | Member of
-------------------+------------------------------------------------+-----------
gitlab | | {}
gitlab-psql | Superuser, Create role, Create DB, Replication | {}
gitlab_replicator | Replication | {}

(10)\dp或\z命令用于显示表的权限分配情况
gitlabhq_production=# \dp abuse_reports
Access privileges
Schema | Name | Type | Access privileges | Column access privileges
--------+---------------+-------+-------------------+--------------------------
public | abuse_reports | table | |
(1 row)

gitlabhq_production=# \z abuse_reports
Access privileges
Schema | Name | Type | Access privileges | Column access privileges
--------+---------------+-------+-------------------+--------------------------
public | abuse_reports | table | |
(1 row)

(10)\x命令-可以把表中的每一行的每列数据都拆分为单行展示
gitlabhq_production=# \x
Expanded display is on.
gitlabhq_production=# \dp
Access privileges
-[ RECORD 1 ]------------+--------------------------------------------
Schema | public
Name | abuse_reports
Type | table
Access privileges |
Column access privileges |

(11)当客户端的字符编码和服务器的不一样时,可能会显示乱码,可以使用\encoding命令来指定客户端的字符编码,如使用\encoding utf8来指定客户端的编码方式为utf8

gitlabhq_production=# \encoding utf8

(12)\pset命令

\pset命令用于指定输出的格式,具体如下:

\pset border 0 : 表示输出内容物边框
\pset border 1 : 表示边框只在内部,默认情况下采用的是该条命令
\pset border 2 : 表示内外都存在边框

(13)\i <SQL文件的路径>
\i <SQL文件的路径>可以在pg中执行外部的SQL语句,这样方便我们执行很复杂的SQL语句。在MySQL中也存在类似的功能,但是实现的方式不一样,在MySQL中执行存储在外部文件中的SQL命令的方式:source <SQL文件的全路径> 或者 \. <SQL文件的全路径>

参考:
http://www.cnblogs.com/wangkangluo1/archive/2012/05/29/2523654.html
http://blog.csdn.net/jpzhu16/article/details/51931357

postgresql的psql常用命令-4的更多相关文章

  1. PostgreSQL客户端psql常用命令

    使用psql客户端访问数据库, 列出了psql常用命令和参数. 常用命令 -- 使用指定用户和IP端口登陆 psql -h 10.43.159.11 -p 5432 -U postgres -W -- ...

  2. PostgreSQL与MySQL常用命令比较&lbrack;转&rsqb;

    PostgreSQL与MySQL常用命令比较 原文链接: http://www.phpwell.com/?p=174 PostgreSQL MySQL 服务启动:1)#service postgres ...

  3. psql常用命令

    cmd命令 pg_ctl --version:查看pgsl版本 pg_ctl -D /xx/pgdata start:启动pgsl数据库 注:必须在环境变量中设置了PGDATA后才能省略-D参数 ,可 ...

  4. 【PostgreSQL-9&period;6&period;3】psql常用命令

    命令 描述 \l 查看数据库 \c 换库 \d 查看所有表 \dt 只显示匹配的表 \di 只显示匹配的索引 \ds 只显示匹配的序列 \dv 只显示匹配的视图 \df 只显示匹配的函数 \d t1 ...

  5. &lbrack;转&rsqb; postgresql常用命令

    PS: 数据库安装后,里面的每个数据库有自己的用户密码,需要dump的时候,指定用户pg_dump -U xxx <数据库>  > 某个地址 最近一直在学习Postgresql,下面 ...

  6. Postgres常用命令之增、删、改、查

    增.删.改.查: postgres=# \password postgres 为postgres进行密码设置: postgres=# CREATE USER test WITH PASSWORD '1 ...

  7. GreenPlum 集群常用命令

    GreenPlum 常用命令 gpstate 命令 参数 作用 gpstate -b => 显示简要状态 gpstate -c => 显示主镜像映射 gpstart -d => 指定 ...

  8. SecureCRT 常用命令

    常用命令:一.ls 只列出文件名 (相当于dir,dir也可以使用) -A:列出所有文件,包含隐藏文件. -l:列表形式,包含文件的绝大部分属性. -R:递归显示. --help:此命令的帮助. 二. ...

  9. SecureCRT 常用命令大全

    常用命令:一.ls 只列出文件名 (相当于dir,dir也可以使用) -A:列出所有文件,包含隐藏文件. -l:列表形式,包含文件的绝大部分属性. -R:递归显示. --help:此命令的帮助. 二. ...

随机推荐

  1. PHP面向对象编程 对象的基本概念 PHP面向对象的基本实践 PHP面向对象的高级实践 PHP面向对象的特殊实践

    再次梳理一下面向对象编程的要点. 此文是以php为例,但思想是通用的. 总结的PHP面向对象编程笔记 对象的基本概念 对象的基本构成 对象包含两部分 一.对象的组成元素 是对象的数据模型,用于描述对象 ...

  2. Servlet使用简介

    Servlet的使用基本包含三个步骤: 1.继承HttpServlet 或实现Servlet 接口 (根据源码分析最终都是对servlet接口的实现) 2.配置地址: 配置web.xml 或者用注解的 ...

  3. Mongodb高级查询【二】

    上一篇文章,写了mongodb常规操作,继续写入,本章主要讲高级查询,文本,聚集,大数据查询. Mongodb的查询语法是很多的,是NOSQL队伍中比较丰富的一个.当然有很多查询跟关系型查询无法相比. ...

  4. &lbrack;知了堂学习笔记&rsqb;&lowbar;ajax的两种使用方式

    一.Ajax概述 1.什么是同步,什么是异步 同步现象:客户端发送请求到服务器端,当服务器返回响应之前,客户端都处于等待 卡死状态 异步现象:客户端发送请求到服务器端,无论服务器是否返回响应,客户端都 ...

  5. redhat杂记

    1.设置sudo权限:修改/etc/sudoers文件,找到root    ALL=(ALL)       ALL,在后面添加nginx ALL=(ALL) NOPASSWD: ALL 2.用sed命 ...

  6. Django templates 模板的语法

    MVC 以及 MTV MVC: M : model -->> 存取数据(模型) V: view -->> 信息的展示(视图) C: controller -->> ...

  7. HDU&period;5628&period;Clarke and math&lpar;狄利克雷卷积 快速幂&rpar;

    \(Description\) \[g(i)=\sum_{i_1|i}\sum_{i_2|i_1}\sum_{i_3|i_2}\cdots\sum_{i_k|i_{k-1}}f(i_k)\ mod\ ...

  8. PostgreSQL统计信息索引页

    磨砺技术珠矶,践行数据之道,追求卓越价值 返回*页:PostgreSQL索引页 本页记录所有本人所写的PostgreSQL的统计信息相关文摘和文章的链接: pg_stats:   --------- ...

  9. 微信小程序-自定义底部导航

    代码地址如下:http://www.demodashi.com/demo/14258.html 一.前期准备工作 软件环境:微信开发者工具 官方下载地址:https://mp.weixin.qq.co ...

  10. CentOS7下的YUM源服务器搭建详解,过程写的很详细(转)

    因为近期公司需要搭建一个YUM源服务器给大量的linux(mini)使用,所以因此在网上找了很多的教程,却没有一个特别详细的,很多都有遗漏,参差不齐.所以,打算自己做完之后方便以后查阅,特出此文档. ...