我在一个企业环境中(运行Debian Linux),没有自己安装它。我使用Navicat或phpPgAdmin访问数据库(如果有帮助的话)。我也没有运行数据库的服务器的shell访问权。
当前回答
公认的答案是很好的,但如果你需要与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...
*/
更多信息在这里和这里。
其他回答
在shell psql.exe中执行
\! psql -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...
*/
更多信息在这里和这里。
检查PostgreSQL数据库版本的有用查询
bash-4.1$ psql
postgres=# SELECT version();
postgres=# SHOW server_version;
检查PostgreSQL客户端版本。
bash-4.1$ psql --version
psql (PostgreSQL) 12.1
如果Select version()返回Memo,尝试这样使用命令:
Select version::char(100)
or
Select version::varchar(100)
在撰写本文时,适用于PgAdmin的当前版本:4.16。
选择需要版本的DB服务器。 单击其中的属性选项卡 右边的窗格。
请看下面的截图: