技术开发 频道

PostgreSQL数据库管理入门之psql工具篇

  【IT168 技术】psql是PostgreSQL自身提供的一款强大的查询和脚本工具,本文将向读者介绍该工具的入门知识。


▲PostgreSQL数据库标志

  一、关于psql

  psql是PostgreSQL自身提供的一款查询工具,也就是说,无论哪种操作系统平台下,该工具都可用,并且使用方法都是一致的。所以,当我们开发可移植的应用软件和技术的时候,该工具是一个理想的选择。

  Psql有两大功能,除了作为交互查询工具使用之外,psql还是一款理想的脚本工具。

  二、使用方法

  本文中,我们假设psql有权访问PostgreSQL服务器,所有连接参数都是缺省的,但是现实中并非总是这样。我们当前的连接参数如下所示:

psql –h hostname –p 5432 –d dbname –U username –W

   下面开始介绍有关的具体操作。psql 最简单的用法就是执行单个SQL命令,并输出命令结果,如下所示:

$ psql -c "SELECT current_time"
timetz
-----------------
20:48:62.384+01
(
1 row)

   带 -c的命令表示为非交互式的。如果您想一次执行多条命令的话,可以将这些命令写入一个文本文件中,然后通过-f 选项来执行它们。下面给出的命令将加载一组命令:

$ psql –f examples.sql

   如果执行成功,会产生如下所示的输出:

SET
SET
SET
SET
SET
SET
CREATE SCHEMA
SET
SET
SET
DROP TABLE
CREATE TABLE
DROP TABLE
CREATE TABLE

   脚本examples.sql非常类似于PostgreSQL备份工具所建立的转储文件,并且它们的类型与结果也是非常相通的。当上面的命令成功执行的时候,PostgreSQL会用命令的名称生成命令标签,就像上面看到的输出结果那样。

  上面的用法类似于批处理方式,实际上psql还可以用于交互方式,并且该方式是默认的工作方式,无需任何选项,例如:

$ psql
postgres
=#

   下面我们开始练习我们的第一条交互式命令,像下面这样:

postgres=# help

   然后,我们就可以输入SQL或其他的命令了。当我们要退出交互模式的时候,可以使用如下所示的命令:

postgres=# \quit

   注意,这里您不能输入quit,也不能输入\exit或者其他选项,而只能是\quit或者\q,后者是前者的简写形式。

  三、命令类型

  psql允许使用两种类型的命令:

  psql "meta-commands"

  SQL

  meta-command 是用于psql客户端,而SQL则发给数据库服务器。meta-command的一个例子是\q,它命令客户端断开连接。所有以反斜线符号\开头的命令都被作为meta-command。

  如果一条命令不是meta-command,那么它就是SQL命令。该命令将一直读取SQL,直到遇见分号为止,所以我们可以将一条较长的SQL命令分到多行中,只要您觉得方便即可。

  命令help是唯一的例外。help命令有两种形式,如下所示:

  \? 提供psql meta - commands命令的帮助信息

  \h 提供特定SQL命令的帮助信息

  下面举例进行说明:

postgres=# \h DELETE
Command:
DELETE
Description:
delete rows of a table
Syntax:
DELETE FROM [ ONLY ] table [ [ AS ] alias ]
[ USING usinglist ]
[ WHERE condition | WHERE CURRENT OF cursor_name ]
[ RETURNING * | output_expression [ AS output_name ] [,]]

   经验表明,这是一种探索和记忆选项和语法好方法。

  四、注释方法

  有两种常用的注释方法,即单行注释和多行注释,下面分别加以解释。单行注释用双破折号表示:

  -- 这里是单行注释

   而多行注释与Java语法类似,如下:

/*
*多行注释
*/

   五、其它功能

  开始的时候,您对于psql的反斜扛命令可能不太适应,但是用一段时间就好了,您会发现,该软件是非常强大的。psql是PostgreSQL最神奇的部分之一,用过其他工具后您会发现,它对于数据库管理任务来说,作用非凡。

  当然,我们可回滚早先的命令历史记录功能。此外,tab补齐功能也是非常有帮助的,因为只要按下TAB键,程序就会帮我们完成后面的语法部分。该功能对于对象名称也同样有效,所以我们只输入前几个字母,然后按Tab键所有可能的选择都会显示出来,这样只要输入足够多的字符,对象名称就会变成唯一选择,这时敲一下Tab键就搞定了。下面是psql其它的有用的特性:

  通知功能

  输出格式化

  使用\timing命令计算执行时间

  输入、输出和编辑命令

  自动起动执行文件:.psqlrc

  可替代的参数(变量)

  访问OS命令行

  六、小结

  psql是PostgreSQL自身提供的一款强大的查询和脚本工具,在本文中,我们向读者详细介绍了该工具的有关入门知识,希望对您能够有所帮助。

0
相关文章