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


当前回答

如果你在debian/ubuntu系统上有对服务器的shell访问权限(问题中提到op没有,但如果你有的话)

sudo apt-cache policy postgresql

它将输出已安装的版本,

postgresql:
  Installed: 9.6+184ubuntu1.1
  Candidate: 9.6+184ubuntu1.1
  Version table:
 *** 9.6+184ubuntu1.1 500
        500 http://in.archive.ubuntu.com/ubuntu artful-updates/main amd64 Packages
        500 http://in.archive.ubuntu.com/ubuntu artful-updates/main i386 Packages
        500 http://security.ubuntu.com/ubuntu artful-security/main amd64 Packages
        500 http://security.ubuntu.com/ubuntu artful-security/main i386 Packages
        100 /var/lib/dpkg/status
     9.6+184ubuntu1 500
        500 http://in.archive.ubuntu.com/ubuntu artful/main amd64 Packages
        500 http://in.archive.ubuntu.com/ubuntu artful/main i386 Packages

其中Installed: <version>是已安装的postgres包版本。

其他回答

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

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替换为此命令。

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

如果Select version()返回Memo,尝试这样使用命令:

Select version::char(100) 

or

Select version::varchar(100)

我相信这就是你要找的,

服务器版本:

pg_config --version

客户端版本:

psql --version

执行命令

psql -V

在哪里

V必须大写。