所有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. (转)MYSQL远程登录权限设置

    转自:http://blog.csdn.net/zhengnz/article/details/6308773 Mysql默认关闭远程登录权限,如下操作允许用户在任意地点登录: 1. 进入mysql, ...

  2. 创建私有maven服务器

    私服的创建 1.下载nexus服务  nexus-2.12.0-01-bundle https://pan.baidu.com/s/1o8OfieI 2.下载maven工具   apache-mave ...

  3. Anroid 手机助手 详细解析 概述(二)

    这篇主要说一下手机插入之后的一些动作. 1)  捕获窗口消息 插入拔出一个USB设备windows 会给所有的窗口发送特定的消息,只要我们捕获这些消息就可以处理设备插入和拔出.需要注意的是插入或者拔出 ...

  4. yum-163源配置

    原文:http://mirrors.163.com/.help/centos.html CentOS镜像使用帮助 收录架构 i386 x86_64 SRPMS 收录版本:所有版本更新时间:每4小时更新 ...

  5. JMS 消息队列

    1.jms  broker服务器:Broker:消息队列核心,相当于一个控制中心,负责路由消息.保存订阅和连接.消息确认和控制事务

  6. how can I make the login form transparent?

    This is how you can make the Login Form transparent: 1. Add this css to Server Module-> Custom cs ...

  7. 【Win】Clso QR Tool 二维码小工具

    一个可以生成并识别二维码的windows小工具,纯绿色.不含糖. 可以通过输入文本生成二维码,或者加载本地图片.剪贴板内的图片,直接解析出二维码内容. 支持自定义LOGO. 下载文件 (当前版本:1. ...

  8. Vuex 拾遗

    引入Vuex的目的:为众多的Vue组件提供一个全局管理共享组件状态的控制中心,当一个共享状态改变时,能使调用该共享状态的组件得到更新.并且使用Vuex的API,每个共享状态的改变都能被追踪. 组件如何 ...

  9. tkinter如何设置界面消失 当制作一个登陆界面时,登陆成功之后,如何让登陆界面本身消失

    tkinter如何设置界面消失 当制作一个登陆界面时,登陆成功之后,如何让登陆界面本身消失 if querySQL.checkAll():#用户名和密码都输入正确 self.root.withdraw ...

  10. odoo开发笔记--模型中常用的方法

    create方法在数据表中插入一条记录(或新建一个对象的resource)格式:def create(self,cr,uid,vals,context={})参数:vals:待新建记录的字段值,是一个 ...