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


当前回答

使用VERSION特殊变量

$psql -c "\echo :VERSION"

其他回答

从PostgreSQL运行这个查询:

SELECT version();

如果你已经在使用for工具(使用DBeaver)来连接PostgreSQL,它将是这样的:

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

3.5版本:

4.1、4.5版本:

如果你正在使用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)

不知道这有多可靠,但你可以自动获得两个版本令牌:

psql --version 2>&1 | tail -1 | awk '{print $3}' | sed 's/\./ /g' | awk '{print $1 "." $2}'

所以你可以构建到二进制文件的路径:

/usr/lib/postgresql/9.2/bin/postgres

只需将9.2替换为此命令。