1189

我在公司环境中(运行 Debian Linux)并且没有自己安装它。我使用 Navicat 或 phpPgAdmin 访问数据库(如果有帮助的话)。我也没有对运行数据库的服务器的 shell 访问权限。

4

20 回答 20

1870

从 PostgreSQL 运行此查询:

SELECT version();
于 2012-12-05T22:42:43.690 回答
627

我相信这就是您正在寻找的,

服务器版本:

pg_config --version

客户端版本:

psql --version
于 2012-12-05T22:44:20.207 回答
233

使用命令行:

服务器版本:

$ postgres -V  # Or --version.  Use "locate bin/postgres" if not found.
postgres (PostgreSQL) 9.6.1
$ postgres -V | awk '{print $NF}'  # Last column is version.
9.6.1
$ postgres -V | egrep -o '[0-9]{1,}\.[0-9]{1,}'  # Major.Minor version
9.6

如果安装了多个 PostgreSQL,或者出现“ postgres: command not found”错误:

$ locate bin/postgres | xargs -i xargs -t '{}' -V  # xargs is intentionally twice.
/usr/pgsql-9.3/bin/postgres -V 
postgres (PostgreSQL) 9.3.5
/usr/pgsql-9.6/bin/postgres -V 
postgres (PostgreSQL) 9.6.1

如果locate没有帮助,请尝试find

$ sudo find / -wholename '*/bin/postgres' 2>&- | xargs -i xargs -t '{}' -V  # xargs is intentionally twice.
/usr/pgsql-9.6/bin/postgres -V 
postgres (PostgreSQL) 9.6.1

虽然postmaster也可以用来代替postgres,但 usingpostgres更可取,因为postmaster它是 . 的不推荐使用的别名postgres

客户端版本:

相关,登录为postgres.

$ psql -V  # Or --version
psql (PostgreSQL) 9.6.1

如果安装了多个 PostgreSQL:

$ locate bin/psql | xargs -i xargs -t '{}' -V  # xargs is intentionally twice.
/usr/bin/psql -V 
psql (PostgreSQL) 9.3.5
/usr/pgsql-9.2/bin/psql -V 
psql (PostgreSQL) 9.2.9
/usr/pgsql-9.3/bin/psql -V 
psql (PostgreSQL) 9.3.5

使用 SQL:

服务器版本:

=> SELECT version();
                                                   version                                                    
--------------------------------------------------------------------------------------------------------------
 PostgreSQL 9.2.9 on x86_64-unknown-linux-gnu, compiled by gcc (GCC) 4.4.7 20120313 (Red Hat 4.4.7-4), 64-bit

=> SHOW server_version;
 server_version 
----------------
 9.2.9

=> SHOW server_version_num;
 server_version_num 
--------------------
 90209

如果更好奇,请尝试=> SHOW all;

客户端版本:

值得一提的是,可以在其中执行 shell 命令以在路径psql中显示可执行文件的客户端版本。psql请注意,运行psql可能与路径中的运行不同。

=> \! psql -V
psql (PostgreSQL) 9.2.9
于 2014-04-29T20:32:54.507 回答
78

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

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)
于 2019-02-04T11:04:40.507 回答
44

公认的答案很好,但是如果您需要以编程方式与 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...
     */  

更多信息在这里这里

于 2017-05-09T14:04:29.133 回答
37

执行命令

psql -V

在哪里

V必须大写。

于 2015-09-25T10:55:29.190 回答
19

在外壳 psql.exe 中,执行

\! psql -V
于 2018-03-21T05:57:14.160 回答
13

pgadmin4通过双击服务器 > server_name_here > 属性选项卡 > 版本可以看到使用它:

3.5版:

pgadmin4 显示 postgres 版本。 服务器 > server_name > 属性 > 版本

4.1、4.5 版:

在此处输入图像描述

于 2018-11-13T19:42:38.147 回答
12

一个简单的方法是通过输入psql --version终端来检查版本

于 2019-02-06T09:21:08.973 回答
9

The pg_config command will report the directory where the PostgreSQL programs are installed (--bindir), the location of C include files (--includedir) and object code libraries (--libdir), and the version of PostgreSQL (--version):

$ pg_config --version
PostgreSQL 9.3.6
于 2015-04-23T06:22:48.220 回答
9

就我而言

$psql
postgres=# \g
postgres=# SELECT version();
                                                       version
---------------------------------------------------------------------------------------------------------------------
 PostgreSQL 8.4.21 on x86_64-pc-linux-gnu, compiled by GCC gcc-4.6.real (Ubuntu/Linaro 4.6.3-1ubuntu5) 4.6.3, 64-bit
(1 row)

希望它会帮助某人

于 2014-07-18T10:29:04.183 回答
8

使用VERSION特殊变量

$psql -c "\echo :VERSION"
于 2019-12-15T07:14:05.393 回答
5

如果您已经在使用 for 工具(使用 DBeaver)连接 PostgreSQL,它将如下所示:

见下图

于 2021-04-13T02:19:59.613 回答
4

如果您在 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 软件包版本。

于 2018-03-25T21:20:44.063 回答
4

检查PostgreSQL 数据库版本的有用查询

bash-4.1$ psql
postgres=# SELECT version();
postgres=# SHOW server_version;

检查 PostgreSQL 客户端版本。

bash-4.1$ psql --version
psql (PostgreSQL) 12.1
于 2021-03-26T13:29:34.437 回答
2

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

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。

于 2014-10-20T11:21:41.020 回答
2

对于 PgAdmin 的当前版本:撰写本文时为 4.16。

  1. 选择您需要其版本的数据库。
  2. 单击右窗格中的属性选项卡。

请看下面的截图: PGAdmin 4.16 显示 DB 版本 10.10

于 2020-01-09T10:33:45.687 回答
1
  1. 使用命令行服务器:
postgres -V

客户:

psql -V
  1. 然后登录到 postgres:
postgres=# select version();

或从 cli:

psql -c "SELECT version();"
  1. 使用VERSION特殊变量 Login 作为 postgres 用户:
sudo su - postgres

然后:

psql -c "\echo :VERSION"

在此处查看本指南以获取完整说明

于 2021-10-06T07:16:29.437 回答
1

这是一个相当古老的问题,有很多很好的答案。我发现从版本 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();查询获得的版本相同。

于 2021-10-29T17:57:15.807 回答
-1

如果Select version()返回 Memo 尝试以这种方式使用命令:

Select version::char(100) 

或者

Select version::varchar(100)
于 2013-08-05T05:03:42.743 回答