所有psql命令都以   \   开头

一、使用psql -l查看有哪些数据库:

-bash-4.2$ psql -l
List of databases
Name | Owner | Encoding | Collate | Ctype | Access privileges
-----------+----------+----------+-------------+-------------+-----------------------
postgres | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 |
template0 | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =c/postgres +
| | | | | postgres=CTc/postgres
template1 | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =c/postgres +
| | | | | postgres=CTc/postgres
test | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 |
(4 rows)

  创建数据库的时候默认是hi从template克隆出来的。

\l  同psql -l

\d  查看表

\c  连接数据库

postgres=# create database testdb;
CREATE DATABASE
postgres=# \c testdb;
You are now connected to database "testdb" as user "postgres".
testdb=# \d
No relations found.
testdb=# create table t(id int primary key, name varchar(40));
CREATE TABLE
testdb=# \d
List of relations
Schema | Name | Type | Owner
--------+------+-------+----------
public | t | table | postgres
(1 row)

psql -h <hostname or ip> -p <port> [数据库名称] [用户名称] 

二、\d

2.1  \d 列出当前数据库所有表;

2.2  \d table_name,显示表结构定义;

testdb=# \d t
Table "public.t"
Column | Type | Modifiers
--------+-----------------------+-----------
id | integer | not null
name | character varying(40) |
Indexes:
"t_pkey" PRIMARY KEY, btree (id)

  \d 显示索引信息。

testdb=# \d t_pkey
Index "public.t_pkey"
Column | Type | Definition
--------+---------+------------
id | integer | id
primary key, btree, for table "public.t"

  \d+ table_name  显示比\d更详细的信息。

如果只想显示匹配的表  \dt

如果只想显示索引    \di

如果只想显示序列   \ds

如果只想显示视图    \dv

如果只想显示函数    \df

显示SQL执行的时间 \timing on

列出所有schema   \n

显示所有表空间  \db

显示数据库中所有角色或者用户   \du   或者   \dg

显示表的权限分配情况    \dp   或者    \z

三、使用\encoding 命令指定字符集   \encoding utf8;

四、\pset命令---用于设置输出的格式

\pset border0:  表示输出内容无表框;

\pset border1:   表示内部显示边框

\pset border2:   表示内部都有边框

testdb=# select * from t;
id | name
----+------
(0 rows) Time: 0.522 ms
testdb=# \pset border 2;
Border style is 2.
testdb=# select * from t;
+----+------+
| id | name |
+----+------+
+----+------+
(0 rows) Time: 0.585 ms
testdb=#

 

五、\x命令,把表中每一行的每列数据都拆分为单行显示;同mysql  /G

六、执行存储在外部文件的SQL命令;

1、 \i <文件名> 执行存储在外部文件中的sql语句或者命令;

2、\echo 显示数据一行信息;

testdb=# \echo hello word
hello word

3、更多命令使用   \?  查看;

七、自动提交方面的技巧。

  在psql中事物是自动提交的。如果不想自动提交,方法有两种

  方法一:运行begin;命令,然后执行dml语句,最后再执行commit或rollback语句。

testdb=# begin;
BEGIN
Time: 0.428 ms
testdb=# update t set name='xxx' where id=1;
UPDATE 1
Time: 0.743 ms
testdb=# select * from t;
+----+------+
| id | name |
+----+------+
| 2 | haha |
| 1 | xxx |
+----+------+
(2 rows) Time: 0.507 ms
testdb=# rollback;
ROLLBACK
Time: 0.317 ms
testdb=# select * from t;
+----+--------+
| id | name |
+----+--------+
| 1 | steven |
| 2 | haha |
+----+--------+
(2 rows) Time: 0.584 ms
testdb=#

 方法二:直接使用psql中的命令关闭自动提交的功能。

\set AUTOCOMMIT off       \\AUTOCOMMIT必须大写

  八、如何得到psql中命令实际执行的SQL

如果在启动psql的命令行中加  -E  ,就可以把pslq中执行的命令实际SQL打印出来:

临时起作用打印SQL的命令:\set ECHO_HIDDEN on | off

 

psql工具使用(二)的更多相关文章

  1. WCF学习之旅—TcpTrace工具(二十六)

    止文(WCF学习之旅—TcpTrace工具(二十五))介绍了关于TcpTrance的一种使用方式,接下来介绍第二种使用方式. 三.通过ListenUri实现基于tcpTracer的消息路由 对于路由的 ...

  2. HTML-DEV-ToolLink(常用的在线字符串编解码、代码压缩、美化、JSON格式化、正则表达式、时间转换工具、二维码生成与解码等工具,支持在线搜索和Chrome插件。)

    HTML-DEV-ToolLink:https://github.com/easonjim/HTML-DEV-ToolLink 常用的在线字符串编解码.代码压缩.美化.JSON格式化.正则表达式.时间 ...

  3. Mac开发必备工具(二)—— iTerm 2

    iTerm 2 简介 iTerm 2 is a terminal emulator for Mac OS X that does amazing things. iTerm 2 有很多能够提升效率的实 ...

  4. Ansible批量自动化管理工具(二)

    Ansible批量自动化管理工具(二) 链接:https://pan.baidu.com/s/1A3Iq3gGkGS27L_Gt37_I0g 提取码:ncy2 复制这段内容后打开百度网盘手机App,操 ...

  5. PostgreSQL下的SQL Shell(psql)工具

    首发微信公众号:SQL数据库运维 原文链接:https://mp.weixin.qq.com/s?__biz=MzI1NTQyNzg3MQ==&mid=2247485130&idx=1 ...

  6. WCF学习之旅—TcpTrace工具(二十五)

    前面的几篇文章,我们学习了怎么开发WCF应用程序与服务,也学习了如何进行WCF的配置.对于Web Service与WCF服务应用,服务端与客户端的通信是通过收发SOAP Message进行,我们如何有 ...

  7. git版本控制工具(二)----本地版本库的常用操作

    ​[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...

  8. [转] Android自动测试之monkeyrunner工具(二)

    monkeyrunner工具  前言: 最近开始研究Android自动化测试方法,对其中的一些工具.方法和框架做了一些简单的整理,其中包括android测试框架.CTS.Monkey.Monkeyru ...

  9. 自动化工具之二:win32gui

    自动化工具win32gui 一.下载安装win32gui 二.Win32gui的使用 1.查找窗体句柄 我们知道的所有空间其实就是窗体,所有的窗口都有一个独立的句柄,要操作任意一个窗体,你都需要找到这 ...

随机推荐

  1. java基础-day19

    第08天 异常 今日内容介绍 u  异常体系&异常处理 u  Throwable常用方法&自定义异常 u  递归 第1章   异常产生&异常处理 1.1      异常概述 什 ...

  2. PAT甲级 1121. Damn Single (25)

    1121. Damn Single (25) 时间限制 300 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue "Dam ...

  3. 计算日期差(Python实现)

    class Solution: def Days(self,year,month,day): if (year%4==0 and year%100!=0) or year%400==0: monthl ...

  4. 七种bond模式说明

    第一种模式:mod=0 ,即:(balance-rr) Round-robin policy(平衡抡循环策略) 特点:传输数据包顺序是依次传输(即:第1个包走eth0,下一个包就走eth1….一直循环 ...

  5. ECCV 2016 paper list

    摘录ECCV2016部分文章,主要有Human pose esimation,  Human activiity / actions, Face alignment, Face detection & ...

  6. Kali Linux渗透测试实战 2.2 操作系统指纹识别

    目录 2.2 操作系统指纹识别 2.2.1 Banner抓取 2.2.2 TCP 和 ICMP 常规指纹识别技术 TCP数据报格式 ICMP首部格式 TTL与TCP窗口大小 FIN探测 BOGUS f ...

  7. 用NginX+keepalived实现高可用的负载均衡

    Table of Contents 1 规划和准备 2 安装 3 配置 3.1 配置NginX 3.2 配置keepalived 3.3 让keepalived监控NginX的状态 4 还可以做什么 ...

  8. ajax调用WebMethed返回处理请求时出错

    ajax post调用WebMethed报错,返回的信息如下: {“Message”:“处理请求时出错”,“StackTrace”:“”,“ExceptionType”:“”} 查了一下WebMeth ...

  9. Linux之IRQ domain

    概述 Linux使用IRQ domain来描述一个中断控制器(IRQ Controller)所管理的中断源.换句话说,每个中断控制器都有自己的domain.我们可以将IRQ Domain看作是IRQ ...

  10. 08_python_文件操作

    一.初始文件操作 打开⽂件的⽅式: r, w, a, r+, w+, a+, rb, wb, ab, r+b, w+b, a+b 默认使⽤的是r(只读)模式 f = open("少妇嫩模.t ...