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


1025

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

Answers:


1644

从PostgreSQL运行以下查询:

SELECT version();

4
在Ubuntu终端上,我的情况没有任何结果
Timo 2014年

22
@Timo,这是要通过PostgreSQL运行的查询。这可以通过pgAdmin或任何其他运行查询的机制来完成。您是否要从Ubuntu Shell运行它?(这将无法正常工作)
2014年

41
也可以从命令行运行psql -c 'SELECT version();'
Aaron Lelevier

3
您可以直接从bash中指定postgres db运行,​​如下所示:psql postgres -c 'SELECT version();'
哈希

22
@Frank H.使用:sudo -u postgres psql postgres -c 'SELECT version()' | grep PostgreSQL应该使您过去“角色'username'不存在”。
马库斯·朱尼乌斯·布鲁图斯

550

我相信这就是您想要的,

服务器版本:

pg_config --version

客户端版本:

psql --version

1
谢谢!这在外壳程序访问可用时适用。不幸的是,就我而言,我没有访问权限。我已经更新了问题。
高度不规则

3
有时客户端版本是您想知道的。
Trejkaz 2013年

12
正如弗兰克指出的那样,这可能是骗人的。psql将连接到任何正在运行的postmaster / postgres数据库进程,并且数据库引擎的版本可能与psql命令的版本不同。
本·罗伯茨

2
pg_config --version可能会产生误导,例如,如果升级Ubuntu服务器并且不运行pg_upgradecluster,pg_config将显示新版本,而不是您仍在使用的版本。
Marius Gedminas

就是这样对我pg_config --versionpsql --versiondyld: Library not loaded: /usr/local/opt/readline/lib/libreadline.7.dylib Referenced from: /usr/local/bin/psql Reason: image not found
有用

217

使用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

如果安装了多个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使用,但使用postgres是更好的,因为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

12
谢谢!,SHOW server_version;脚本中的十分方便,可以避免不得不分析的长字符串SELECT version();
vaab 2014年

非常感谢。人们没有意识到,对于发出SQL命令,您至少必须知道一个角色才能连接到数据库。但是,使用postgres -V时,您不必知道连接数据库即可知道其版本。
ychaouche 2014年

在CLI一号线假设超级用户访问:psql postgres -c "SHOW server_version" -t -A-t删除标题,-A删除对齐空格。
Pocketsand '17

SHOW server_version_num特别感谢您,这对于不平等非常有用。
eswald

63

如果您使用的是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)

37

可以接受的答案很好,但是如果您需要与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...
     */  

更多信息在这里这里


36

执行命令

psql -V

哪里

V必须大写。


8
那是psql(客户端)版本,而不是 Postgres 服务器的版本。
a_horse_with_no_name

审稿人:如果答案是错误的,但是是答案(如评论所暗示),则不建议删除:downvote!例如,请参阅“ 您做错了:低质量帖子队列中的理智请求 ”和“ 答案回答错误问题时,它不是答案吗? ”。这是一个答案。您可能不同意,但这只是为了回答问题。
李慧夏


12

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


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

12

pgadmin4双击服务器> server_name_here>属性选项卡>版本,可以看到它的使用情况:

版本3.5:

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

版本4.1、4.5:

在此处输入图片说明


没看到 使用pgadmin 4版本4.1。
faintsignal

1
@faintsignal添加了pgadmin4 v4.1的屏幕截图,该版本跳转非常迅速。
jmunsch

1
哦我的错 我以为您在服务器上单击鼠标右键,这将导致出现一个不同的“属性”对话框。谢谢!
faintsignal

9

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

$ pg_config --version
PostgreSQL 9.3.6

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)

希望对别人有帮助


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软件包版本。


1
作为类似的想法,我跑来$ yum list查看已安装某些Postgresql软件包。
帕特里克

这很好。您能否说明在ubuntu 16.04上如何从9.6升级到10
kRazzy R

4

使用VERSION特殊变量

$psql -c "\echo :VERSION"

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。


psql --version返回psql客户端的版本,而不是 Postgres服务器的版本
a_horse_with_no_name

1

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

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

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


0

如果Select version()返回了Memo,请尝试通过以下方式使用命令:

Select version::char(100) 

要么

Select version::varchar(100)

2
select version()::varchar(100);为我工作,但与version()
isaaclw
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.