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


当前回答

如果你正在使用CLI并且你是postgres用户,那么你可以这样做:

psql -c "SELECT version();"

可能的输出:

                                                         version                                                         
-------------------------------------------------------------------------------------------------------------------------
 PostgreSQL 11.1 (Debian 11.1-3.pgdg80+1) on x86_64-pc-linux-gnu, compiled by gcc (Debian 4.9.2-10+deb8u2) 4.9.2, 64-bit
(1 row)

其他回答

公认的答案是很好的,但如果你需要与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...
     */  

更多信息在这里和这里。

从PostgreSQL运行这个查询:

SELECT version();

我相信这就是你要找的,

服务器版本:

pg_config --version

客户端版本:

psql --version

使用命令行 服务器:

postgres -V

客户:

psql -V

登录postgres,然后:

postgres=# select version();

或者来自cli:

psql -c "SELECT version();"

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

sudo su - postgres

然后:

psql -c "\echo :VERSION"

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

这是一个很老的问题,有很多很好的答案。我发现从版本12开始,简单地调用客户机就可以告诉我需要知道的内容,但是我在服务器的shell上运行它们。下面的示例带有输出。

当我在第12版的时候

$ sudo su postgres -c "psql"
psql (12.8 (Ubuntu 12.8-0ubuntu0.20.04.1))

我读这个是因为客户端和服务器都在版本12。

在我把Ubuntu从20.04升级到21.04之后:

$ sudo su postgres -c "psql"
psql (13.4 (Ubuntu 13.4-0ubuntu0.21.04.1), server 12.8 (Ubuntu 12.8-0ubuntu0.20.04.1))

它清楚地告诉我客户端在版本13上,但服务器仍然在版本12上,正如我确认的那样:

$ pg_lsclusters
Ver Cluster Port Status Owner    Data directory              Log file
12  main    5432 online postgres /var/lib/postgresql/12/main /var/log/postgresql/postgresql-12-main.log

顺便说一下,注意这个误导性的结果,在这个阶段:

$ pg_config --version
PostgreSQL 13.4 (Ubuntu 13.4-0ubuntu0.21.04.1)

我升级到14版后:

$ sudo su postgres -c "psql"
psql (14.0 (Ubuntu 14.0-1.pgdg21.04+1))
Type "help" for help.

postgres=#

再一次,我将其解释为客户端和服务器都在版本14上,再次确认:

$ pg_lsclusters
Ver Cluster Port Status                Owner    Data directory              Log file
12  main    5432 down,binaries_missing postgres /var/lib/postgresql/12/main /var/log/postgresql/postgresql-12-main.log
14  main    5433 online                postgres /var/lib/postgresql/14/main /var/log/postgresql/postgresql-14-main.log

顺便说一下,这个版本与运行SELECT version()获得的版本相同;查询