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

Hig*_*lar 958 postgresql

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

Hig*_*lar 1542

从PostgreSQL运行此查询:

SELECT version();
Run Code Online (Sandbox Code Playgroud)

  • 这也可以从命令行运行`psql -c'SELECT version();'` (35认同)
  • @Frank H.使用:`sudo -u postgres psql postgres -c'SELECT version()'| grep PostgreSQL`应该让你过去"角色'用户名'不存在". (20认同)
  • @Timo,这是一个通过PostgreSQL运行的查询.这可以通过pgAdmin或任何其他运行查询的机制来完成.你试图从Ubuntu shell运行它吗?(这不起作用) (19认同)
  • 在Ubuntu的终端上没有导致我的情况 (4认同)
  • 您可以直接从指定postgres db的bash运行,如下所示:`psql postgres -c'SELECT version();'` (3认同)
  • 它在pgAdmin 4中使用时效果很好 (2认同)

小智 501

我相信这就是你要找的东西,

服务器版本:

pg_config --version
Run Code Online (Sandbox Code Playgroud)

客户版本:

psql --version
Run Code Online (Sandbox Code Playgroud)

  • 正如弗兰克所说,这可能是骗人的.psql将连接到正在运行的postmaster/postgres数据库进程,并且数据库引擎可能与psql命令的版本不同. (10认同)
  • 谢谢!这适用于 shell 访问可用时。不幸的是,就我而言,我没有这种访问权限;我已经更新了问题。 (3认同)
  • 有时客户端版本无论如何都是您想要知道的. (3认同)
  • `pg_config --version` 可能会产生误导,例如,如果您升级 Ubuntu 服务器并且不运行 `pg_upgradecluster`,pg_config 将显示新版本而不是您仍在使用的版本。 (2认同)

Acu*_*nus 210

使用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 version
9.6
Run Code Online (Sandbox Code Playgroud)

如果有多个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
Run Code Online (Sandbox Code Playgroud)

如果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
Run Code Online (Sandbox Code Playgroud)

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

客户版本:

相关,登录为postgres.

$ psql -V  # Or --version
psql (PostgreSQL) 9.6.1
Run Code Online (Sandbox Code Playgroud)

如果有多个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
Run Code Online (Sandbox Code Playgroud)

使用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
Run Code Online (Sandbox Code Playgroud)

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

客户版本:

对于它的价值,可以在其中执行shell命令以在路径中psql显示psql可执行文件的客户端版本.请注意,运行psql可能与路径中的运行不同.

=> \! psql -V
psql (PostgreSQL) 9.2.9
Run Code Online (Sandbox Code Playgroud)

  • 谢谢!,``SHOW server_version;``在脚本中非常方便,以避免在``SELECT version();``的长字符串中解析. (12认同)

sim*_*eco 53

如果您使用的是CLI并且您是postgres用户,则可以执行以下操作:

psql -c "SELECT version();"
Run Code Online (Sandbox Code Playgroud)

可能的输出:

                                                         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)
Run Code Online (Sandbox Code Playgroud)


vip*_* cp 37

执行命令

psql -V
Run Code Online (Sandbox Code Playgroud)

哪里

V必须是资本.

  • 那是`psql`(客户端)版本,**不是Postgres**服务器**的版本. (8认同)

Mic*_*zzi 35

接受的答案很棒,但是如果你需要以编程方式与PostgreSQL版本进行交互,那么最好这样做:

SELECT current_setting('server_version_num'); -- Returns 90603 (9.6.3)
-- Or using SHOW command:
SHOW server_version_num; -- Returns 90603 too
Run Code Online (Sandbox Code Playgroud)

它将服务器版本作为整数返回.这是在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...
     */  
Run Code Online (Sandbox Code Playgroud)

更多信息在这里这里.


Die*_*ezú 18

在shell psql.exe中,执行

\! psql -V
Run Code Online (Sandbox Code Playgroud)

  • 这将为他提供postgre客户端的版本.我认为OP要求sql server版本. (13认同)

小智 14

  1. 使用命令行服务器:
postgres -V
Run Code Online (Sandbox Code Playgroud)

客户:

psql -V
Run Code Online (Sandbox Code Playgroud)
  1. 然后登录 postgres:
postgres=# select version();
Run Code Online (Sandbox Code Playgroud)

或者来自 cli:

psql -c "SELECT version();"
Run Code Online (Sandbox Code Playgroud)
  1. 使用VERSION特殊变量以 postgres 用户身份登录:
sudo su - postgres
Run Code Online (Sandbox Code Playgroud)

然后:

psql -c "\echo :VERSION"
Run Code Online (Sandbox Code Playgroud)

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


jmu*_*sch 12

pgadmin4通过双击Servers> server_name_here> Properties> Version可以看到使用它:

版本3.5:

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

版本4.1:

在此输入图像描述

  • @faintsignal 添加了 pgadmin4 v4.1 的屏幕截图,版本控制跳跃发生得非常快。 (2认同)
  • 哦,我的错误。我以为您右键单击了服务器,这会导致一个不同的“属性”对话框。谢谢! (2认同)

Ale*_*Trn 12

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

  • 请注意,这只会告诉您客户端版本,这可能与服务器版本不同。有关规范的方法,请参见@simhumileco的答案。 (3认同)

小智 11

从 PostgreSQL 运行此查询: SELECT version();


Sth*_*ita 9

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

见下图


Vik*_*dia 8

就我而言

$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)
Run Code Online (Sandbox Code Playgroud)

希望它会帮助某人


Don*_*ato 8

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

$ pg_config --version
PostgreSQL 9.3.6
Run Code Online (Sandbox Code Playgroud)


Fra*_*Liu 8

使用VERSION特殊变量

$psql -c "\echo :VERSION"
Run Code Online (Sandbox Code Playgroud)


小智 7

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

bash-4.1$ psql
postgres=# SELECT version();
postgres=# SHOW server_version;
Run Code Online (Sandbox Code Playgroud)

检查 PostgreSQL 客户端版本。

bash-4.1$ psql --version
psql (PostgreSQL) 12.1
Run Code Online (Sandbox Code Playgroud)


Mar*_*rty 5

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

sudo apt-cache policy postgresql
Run Code Online (Sandbox Code Playgroud)

这将输出已安装的版本,

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
Run Code Online (Sandbox Code Playgroud)

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

  • 出于类似的想法,我运行“$ yum list”来查看是否安装了某些 Postgresql 软件包。 (2认同)

Lef*_*ogh 5

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

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

请参阅下面的屏幕截图: PGAdmin 4.16 显示数据库版本 10.10