我在一个企业环境中(运行Debian Linux),没有自己安装它。我使用Navicat或phpPgAdmin访问数据库(如果有帮助的话)。我也没有运行数据库的服务器的shell访问权。


当前回答

使用VERSION特殊变量

$psql -c "\echo :VERSION"

其他回答

使用pgadmin4,双击Servers > server_name_here > Properties选项卡> Version:

3.5版本:

4.1、4.5版本:

在撰写本文时,适用于PgAdmin的当前版本:4.16。

选择需要版本的DB服务器。 单击其中的属性选项卡 右边的窗格。

请看下面的截图:

公认的答案是很好的,但如果你需要与PostgreSQL版本进行编程交互,可能更好的做法是:

SELECT current_setting('server_version_num'); -- Returns 90603 (9.6.3)
-- Or using SHOW command:
SHOW server_version_num; -- Returns 90603 too

它将以整数形式返回服务器版本。这是如何在PostgreSQL源代码中测试服务器版本的,例如:

/*
 * This is a C code from pg_dump source.
 * It will do something if PostgreSQL remote version (server) is lower than 9.1.0
 */
if (fout->remoteVersion < 90100)
    /*
     * Do something...
     */  

更多信息在这里和这里。

使用命令行 服务器:

postgres -V

客户:

psql -V

登录postgres,然后:

postgres=# select version();

或者来自cli:

psql -c "SELECT version();"

使用VERSION特殊变量 以postgres用户登录:

sudo su - postgres

然后:

psql -c "\echo :VERSION"

请查看这里的指南以获得完整的解释

执行命令

psql -V

在哪里

V必须大写。