所有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. 前端- html 和css

    html HTML 指超文本标签语言. HTML 是通向 WEB 技术世界的钥匙. html属性:所有标签的通用属性 html事件:On...html5加了很多事件 html视频/音频:处理音视频 h ...

  2. (转)memcached注意事项

    转自:http://www.kaifajie.cn/kaiyuan_qita/8656.html 1.   key值最大长度? memcached的key的最大长度是250个字符. 注意250是mem ...

  3. 关于MVC视图传参

    转自:http://q.cnblogs.com/q/48477/

  4. android-基础编程-ListView

    ListView主要包括view和数据源.其数据适配器列表分为三种,ArrayAdapter,SimpleAdapter和SimpleCursorAdapter. ListView的没有oom原因.经 ...

  5. 冲刺博客NO.2

    今日做了什么:   了解到Mob.com有全球短信验证功能,按照官方集成文档下载了SDK,但是还不会写(正在慕课网上学习). 掌握了android开发的一些流程,熟悉了android studio的语 ...

  6. 用delegate实现.NET应用程序的同步函数的异步调用-.NET多线程编程实践之一

    在C++中有2种类型的线程:UI Thread和Worker Thread,前者是基于用户界面的有消息循环的线程.后者是没有用户界面的侧重于大时空运算的线程.直接调用Windows相关线程及同步对象的 ...

  7. verilog选择数据类型时常犯的错误

    •    信号可以分为端口信号和内部信号.出现在端口列表中的信号是端口信号,其它的信号为内部信号. •    对于端口信号,输入端口只能是net类型.输出端口可以是net类型,也可以是register ...

  8. numpy和pandas和matplotlib用法

    numpy result = [ [0, 10, 20, 30, 40], [10, 23, 33, 43, 53], [20, 83, 23, 55, 33], [30, 93, 44, 22, 5 ...

  9. AngularJS 服务 provider factory service及区别

    一.概念说明 1.服务是对公共代码的抽象,如多个控制器都出现了相似代码,把他们抽取出来,封装成一个服务,遵循DRY原则,增强可维护性,剥离了和具体表现相关的部分,聚焦于业务逻辑或交互逻辑,更加容易被测 ...

  10. ASP.NET Web API 框架研究 Controller创建 HttpController 类型解析 选择 创建

    上一篇介绍了HttpController的一些细节,接下来说下HttpController 类型解析.选择和创建.生产HttpController实例的生产线如下图: 一.涉及的类及源码分析 涉及的类 ...