我正在运行哪个版本的PostgreSQL?

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

979963 次浏览

从PostgreSQL运行此查询:

SELECT version();

我相信这就是你要找的,

服务器版本:

pg_config --version

客户端版本:

psql --version

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

Select version::char(100)

Select version::varchar(100)

使用CLI:

服务器版本:

$ 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 version9.6

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

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

虽然也可以使用postmaster代替postgres,但使用postgres更可取,因为postmasterpostgres的弃用别名。

客户端版本:

相关的,以#0登录

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

如果安装了多个PostgreSQL:

$ locate bin/psql | xargs -i xargs -t '{}' -V  # xargs is intentionally twice./usr/bin/psql -Vpsql (PostgreSQL) 9.3.5/usr/pgsql-9.2/bin/psql -Vpsql (PostgreSQL) 9.2.9/usr/pgsql-9.3/bin/psql -Vpsql (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;

客户端版本:

不管怎样,可以在psql中执行shell命令,以在路径中显示psql可执行文件的客户端版本。请注意,正在运行的psql可能与路径中的不同。

=> \! psql -Vpsql (PostgreSQL) 9.2.9

在我的情况下

$psqlpostgres=# \gpostgres=# 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)

希望它能帮助别人

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

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

pg_config命令将报告安装PostgreSQL程序的目录(--bindr)、C包含文件的位置(--enddedir)和目标代码库(--libdir),以及PostgreSQL的版本(--version):

$ pg_config --versionPostgreSQL 9.3.6

执行命令

psql -V

哪里

V必须在首都。

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

更多信息这里这里

在shellpsql.exe中,执行

\! psql -V

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

sudo apt-cache policy postgresql

这将输出安装的版本,

postgresql:Installed: 9.6+184ubuntu1.1Candidate: 9.6+184ubuntu1.1Version table:*** 9.6+184ubuntu1.1 500500 http://in.archive.ubuntu.com/ubuntu artful-updates/main amd64 Packages500 http://in.archive.ubuntu.com/ubuntu artful-updates/main i386 Packages500 http://security.ubuntu.com/ubuntu artful-security/main amd64 Packages500 http://security.ubuntu.com/ubuntu artful-security/main i386 Packages100 /var/lib/dpkg/status9.6+184ubuntu1 500500 http://in.archive.ubuntu.com/ubuntu artful/main amd64 Packages500 http://in.archive.ubuntu.com/ubuntu artful/main i386 Packages

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

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

版本3.5:

pgadmin4 show postgres version. Servers>server_name>Properties>Version

版本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来检查版本

使用VERSION特殊变量

$psql -c "\echo :VERSION"

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

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

见下图:PGAdmin 4.16显示数据库版本10.10

有用的查询到ChckPostgreSQL数据库版本

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

检查PostgreSQL客户端版本。

bash-4.1$ psql --versionpsql (PostgreSQL) 12.1

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

见下图

  1. 使用命令行服务器:
postgres -V

客户:

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

或者从cli:

psql -c "SELECT version();"
  1. 使用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_lsclustersVer Cluster Port Status Owner    Data directory              Log file12  main    5432 online postgres /var/lib/postgresql/12/main /var/log/postgresql/postgresql-12-main.log

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

$ pg_config --versionPostgreSQL 13.4 (Ubuntu 13.4-0ubuntu0.21.04.1)

在I升级到版本14之后:

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

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

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

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

从PostgreSQL运行此查询:选择版本();