ChatGPT解决这个技术问题 Extra ChatGPT

我运行的是哪个版本的 PostgreSQL?

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


H
Highly Irregular

从 PostgreSQL 运行此查询:

SELECT version();

我在 Ubuntu 的终端中没有结果
@Timo,这是一个通过 PostgreSQL 运行的查询。这可以通过 pgAdmin 或任何其他运行查询的机制来完成。您是否尝试从 Ubuntu shell 运行它? (这行不通)
这也可以使用 psql -c 'SELECT version();' 从命令行运行
您可以直接从指定 postgres 数据库的 bash 运行,如下所示:psql postgres -c 'SELECT version();'
@Frank H. Using: sudo -u postgres psql postgres -c 'SELECT version()' | grep PostgreSQL 应该让你过去“角色'用户名'不存在”。
T
Tim Büthe

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

服务器版本:

pg_config --version

客户端版本:

psql --version

谢谢!这适用于 shell 访问可用时。不幸的是,就我而言,我没有那种访问权限;我已经更新了这个问题。
有时客户端版本是您无论如何都想知道的。
正如弗兰克所说,这可能具有欺骗性。 psql 将连接到正在运行的任何 postmaster/postgres 数据库进程,并且数据库引擎可能与 psql 命令的版本不同。
pg_config --version 可能会产生误导,例如,如果您升级 Ubuntu 服务器但不运行 pg_upgradecluster,pg_config 将显示新版本而不是您仍在使用的版本。
只是这对我有用:pg_config --version 命令:psql --version不起作用,对此抱怨:dyld: Library not loaded: /usr/local/opt/readline/lib/libreadline.7.dylib Referenced from: /usr/local/bin/psql Reason: image not found
A
Asclepius

使用命令行:

服务器版本:

$ 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,因为 postmasterpostgres 的已弃用别名。

客户端版本:

相关,login as 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;

客户端版本:

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

=> \! psql -V
psql (PostgreSQL) 9.2.9

谢谢!,SHOW server_version; 在脚本中非常方便,以避免在 SELECT version(); 的长字符串中进行解析。
非常感谢。人们没有意识到,要发出 SQL 命令,您必须至少知道一个角色才能连接到数据库。但是使用 postgres -V 你不必知道连接到数据库就可以知道它的版本。
CLI 中的一行假设超级用户访问:psql postgres -c "SHOW server_version" -t -A-t 删除标题,-A 删除对齐空白。
特别感谢您提供的 SHOW server_version_num,这对于处理不等式非常有用。
s
simhumileco

如果您正在使用 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)

M
Michel Milezzi

公认的答案很好,但是如果您需要以编程方式与 PostgreSQL 版本进行交互,最好这样做:

SELECT current_setting('server_version_num'); -- Returns 90603 (9.6.3)
-- Or using SHOW command:
SHOW server_version_num; -- Returns 90603 too

它将以整数形式返回服务器版本。这是在 PostgreSQL source 中测试服务器版本的方式,例如:

/*
 * 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...
     */  

更多信息 herehere


B
Bhavesh Odedra

执行命令

psql -V

在哪里

必须大写。


那是 psql(客户端)版本,不是 Postgres 服务器的版本。
reviewers:如果答案是错误的但是是一个答案(就像评论暗示的那样),不建议删除:投反对票!例如,参见“You're doing it wrong: A plea for sanity in the Low Quality Posts queue”和“When an answer answers the wrong question, is it Not An Answer?”。这是一个答案。您可能不同意它,但它试图回答这个问题。
这是最好的答案。上面的许多答案都返回客户端的版本而不是服务器。
M
MD. Khairul Basar

在外壳 psql.exe 中,执行

\! psql -V

这将为他提供 postgre 客户端的版本。我认为 OP 要求提供 sql server 版本。
j
jmunsch

使用 pgadmin4 可以通过双击 Servers > 查看它。 server_name_here >属性选项卡 >版本:

3.5版:

https://i.stack.imgur.com/5ev2W.png

4.1、4.5 版:

https://i.stack.imgur.com/gijiF.png


不要看到它。使用 pgadmin 4 版本 4.1。
@faintsignal 为 pgadmin4 v4.1 添加了屏幕截图,版本控制跳转发生得非常快。
哦,我的错。我以为您正在右键单击服务器,这会导致不同的“属性”对话框。谢谢!
A
Ali Tourani

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


请注意,这只会告诉您客户端版本,这很可能与服务器不同。有关规范的方式,请参阅@simhumileco 的答案。
V
Vikas Hardia

就我而言

$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)

希望它会帮助某人


D
Donato

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

$ pg_config --version
PostgreSQL 9.3.6

F
Frank Liu

使用 VERSION 特殊变量

$psql -c "\echo :VERSION"

\ 命令由 psql 客户端提供。这不是您可以放入其他客户端的 SQL 语句。问题是关于 Navicat 等,它们不支持这种语法。
S
Sthita

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

https://i.stack.imgur.com/2t2Xv.png


A
All Іѕ Vаиітy

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


作为类似的想法,我运行 $ yum list 来查看是否安装了某些 Postgresql 包。
这很好用。您能否说明如何在 ubuntu 16.04 上从 9.6 升级到 10。
s
santosh tiwary

检查有用的查询PostgreSQL Database Version

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

检查 PostgreSQL 客户端版本。

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

E
Eutychus

使用命令行服务器:

postgres -V

客户:

psql -V

然后登录到 postgres:

postgres=# select version();

或从 cli:

psql -c "SELECT version();"

使用 VERSION 特殊变量以 postgres 用户身份登录:

sudo su - postgres

然后:

psql -c "\echo :VERSION"

查看本指南 here 以获得完整说明


M
Martin

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

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 服务器的版本
L
Lefty G Balogh

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

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

https://i.stack.imgur.com/5ZKrQ.png


N
Nagev

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

在我 upgraded 到版本 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(); 查询获得的版本相同。


G
Gidil

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

Select version::char(100) 

或者

Select version::varchar(100)

select version()::varchar(100); 为我工作,但与 version() 相同
L
Leo

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