我在公司环境中(运行 Debian Linux)并且没有自己安装它。我使用 Navicat 或 phpPgAdmin 访问数据库(如果有帮助的话)。我也没有对运行数据库的服务器的 shell 访问权限。
从 PostgreSQL 运行此查询:
SELECT version();
我相信这就是您正在寻找的,
服务器版本:
pg_config --version
客户端版本:
psql --version
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
使用命令行:
服务器版本:
$ 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
的已弃用别名。
客户端版本:
$ 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();
的长字符串中进行解析。
psql postgres -c "SHOW server_version" -t -A
。 -t
删除标题,-A
删除对齐空白。
SHOW server_version_num
,这对于处理不等式非常有用。
如果您正在使用 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)
公认的答案很好,但是如果您需要以编程方式与 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...
*/
执行命令
psql -V
在哪里
必须大写。
psql
(客户端)版本,不是 Postgres 服务器的版本。
在外壳 psql.exe 中,执行
\! psql -V
使用 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
一个简单的方法是通过在终端中输入 psql --version
来检查版本
就我而言
$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)
希望它会帮助某人
pg_config 命令将报告 PostgreSQL 程序的安装目录 (--bindir)、C 包含文件 (--includedir) 和目标代码库 (--libdir) 的位置以及 PostgreSQL 的版本 (--version) :
$ pg_config --version
PostgreSQL 9.3.6
使用 VERSION
特殊变量
$psql -c "\echo :VERSION"
如果您已经在使用 for 工具(使用 DBeaver)连接 PostgreSQL,它将如下所示:
https://i.stack.imgur.com/2t2Xv.png
如果您在 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 包。
检查有用的查询PostgreSQL Database Version
bash-4.1$ psql
postgres=# SELECT version();
postgres=# SHOW server_version;
检查 PostgreSQL 客户端版本。
bash-4.1$ psql --version
psql (PostgreSQL) 12.1
使用命令行服务器:
postgres -V
客户:
psql -V
然后登录到 postgres:
postgres=# select version();
或从 cli:
psql -c "SELECT version();"
使用 VERSION 特殊变量以 postgres 用户身份登录:
sudo su - postgres
然后:
psql -c "\echo :VERSION"
查看本指南 here 以获得完整说明
不知道这有多可靠,但是您可以完全自动获得两个版本令牌:
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 服务器的版本
对于 PgAdmin 的当前版本:撰写本文时为 4.16。
选择您需要其版本的数据库。单击右窗格中的属性选项卡。
https://i.stack.imgur.com/5ZKrQ.png
这是一个相当古老的问题,有很多很好的答案。我发现从版本 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();
查询获得的版本相同。
如果 Select version()
返回 Memo 尝试以这种方式使用命令:
Select version::char(100)
或者
Select version::varchar(100)
select version()::varchar(100);
为我工作,但与 version()
相同
从 PostgreSQL 运行此查询:SELECT version();
psql -c 'SELECT version();'
从命令行运行psql postgres -c 'SELECT version();'
sudo -u postgres psql postgres -c 'SELECT version()' | grep PostgreSQL
应该让你过去“角色'用户名'不存在”。