我正在运行哪个版本的 PostgreSQL?
- 2024-11-06 08:35:00
- admin 原创
- 40
问题描述:
我在公司环境中(运行 Debian Linux),自己没有安装它。我使用 Navicat 或 phpPgAdmin(如果有帮助的话)访问数据库。我也没有运行数据库的服务器的 shell 访问权限。
解决方案 1:
从 PostgreSQL 运行此查询:
SELECT version();
解决方案 2:
我相信这就是你要找的,
服务器版本:
pg_config --version
客户端版本:
psql --version
解决方案 3:
使用 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
解决方案 4:
如果您正在使用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)
解决方案 5:
接受的答案很棒,但如果您需要以编程方式与 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...
*/
更多信息请见这里和这里。
解决方案 6:
执行命令
psql -V
在哪里
V必须大写。
解决方案 7:
在 shell psql.exe 中,执行
! psql -V
解决方案 8:
pgadmin4
可以通过双击服务器 > server_name_here > 属性选项卡 > 版本来使用它:
版本 3.5:
版本 4.1、4.5:
解决方案 9:
使用命令行服务器:
postgres -V
客户:
psql -V
然后登录 postgres:
postgres=# select version();
或者从 CLI:
psql -c "SELECT version();"
使用
VERSION
特殊变量以 postgres 用户身份登录:
sudo su - postgres
然后:
psql -c "echo :VERSION"
请参阅此处的指南以获取完整解释
解决方案 10:
psql --version
一种简单的方法是通过在终端中输入来检查版本
解决方案 11:
从 PostgreSQL 运行此查询:SELECT version();
解决方案 12:
使用VERSION
特殊变量
$psql -c "echo :VERSION"
解决方案 13:
就我而言
$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)
希望它能帮助别人
解决方案 14:
pg_config 命令将报告 PostgreSQL 程序的安装目录(--bindir)、C 包含文件(--includedir)和目标代码库(--libdir)的位置以及 PostgreSQL 的版本(--version):
$ pg_config --version
PostgreSQL 9.3.6
解决方案 15:
如果您已经使用工具(使用 DBeaver)连接 PostgreSQL,它将看起来像这样:
解决方案 16:
检查PostgreSQL 数据库版本的有用查询
bash-4.1$ psql
postgres=# SELECT version();
postgres=# SHOW server_version;
检查 PostgreSQL 客户端版本。
bash-4.1$ psql --version
psql (PostgreSQL) 12.1
解决方案 17:
如果你在 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 包版本。
解决方案 18:
对于 PgAdmin 的当前版本:撰写本文时为 4.16。
选择您需要的版本的数据库服务器。
单击右侧窗格中的属性选项卡。
请参阅下面的截图:
解决方案 19:
这是一个相当老的问题,有很多很好的答案。我发现从版本 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)
升级到版本 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();
。
解决方案 20:
不知道这有多可靠,但你可以完全自动地获得两个版本的令牌:
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 即可。
解决方案 21:
~$ psql --version
psql (PostgreSQL) 16.2 (Ubuntu 16.2-1.pgdg22.04+1)
我在 ubuntu CLI 上运行了这个命令,找到了这个版本
解决方案 22:
如果Select version()
返回 Memo,请尝试按以下方式使用命令:
Select version::char(100)
或者
Select version::varchar(100)
解决方案 23:
我进入 postgres 目录并输入 cmd => psql --version
解决方案 24:
**Using any of below commands we can get PostgreSQL Server version:
<br>
Below commands needs to be run from psql tool:<br>**
show server_version;<br>
select version();<br>
<br>
**Below commands needs to run from Linux shell:<br>**
cat PG_VERSION -- This is there in data directory(show data_directory;)<br>
pg_config --version;<br>
运行代码片段Hide results展开片段
- 2024年20款好用的项目管理软件推荐,项目管理提效的20个工具和技巧
- 2024年开源项目管理软件有哪些?推荐5款好用的项目管理工具
- 项目管理软件有哪些?推荐7款超好用的项目管理工具
- 项目管理软件哪个最好用?盘点推荐5款好用的项目管理工具
- 项目管理软件有哪些最好用?推荐6款好用的项目管理工具
- 项目管理软件有哪些,盘点推荐国内外超好用的7款项目管理工具
- 2024项目管理软件排行榜(10类常用的项目管理工具全推荐)
- 项目管理软件排行榜:2024年项目经理必备5款开源项目管理软件汇总
- 2024年常用的项目管理软件有哪些?推荐这10款国内外好用的项目管理工具
- 项目管理必备:盘点2024年13款好用的项目管理软件