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

2024-11-06 08:35:00
admin
原创
74
摘要:问题描述:我在公司环境中(运行 Debian Linux),自己没有安装它。我使用 Navicat 或 phpPgAdmin(如果有帮助的话)访问数据库。我也没有运行数据库的服务器的 shell 访问权限。解决方案 1:从 PostgreSQL 运行此查询:SELECT version(); 解决方案 2:我...

问题描述:

我在公司环境中(运行 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:

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

版本 4.1、4.5:

在此处输入图片描述

解决方案 9:

  1. 使用命令行服务器:

postgres -V

客户:

psql -V
  1. 然后登录 postgres:

postgres=# select version();

或者从 CLI:

psql -c "SELECT version();"
  1. 使用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。

  1. 选择您需要的版本的数据库服务器。

  2. 单击右侧窗格中的属性选项卡。

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

解决方案 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展开片段

相关推荐
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   681  
  在项目管理领域,集成产品开发(IPD)流程以其高效、协同的特点,被众多企业视为提升产品竞争力的关键。IPD流程强调跨部门、跨职能的紧密合作,以确保产品从概念到市场各个环节的无缝衔接。然而,实现这一目标并非易事,它需要企业深刻理解并掌握IPD流程中的跨部门协作艺术。本文将深入探讨IPD流程中跨部门协作的三个关键点,旨在为...
IPD项目管理咨询   9  
  掌握IPD流程图:提升团队协作的关键路径在当今快速变化的商业环境中,团队协作的效率与效果直接关系到项目的成功与否。集成产品开发(Integrated Product Development,简称IPD)作为一种先进的研发管理理念,通过跨部门、跨领域的协同工作,能够显著提升产品开发的速度与质量。而IPD流程图,则是这一理...
IPD流程阶段   9  
  IPD流程概述:理解其核心价值与实施背景集成产品开发(Integrated Product Development,简称IPD)是一种先进的产品开发管理理念,它强调跨部门协作、市场导向和快速响应变化的能力。IPD流程不仅关注产品本身的技术创新,更注重将市场、研发、生产、销售等各个环节紧密集成,以实现产品从概念到市场的高...
华为IPD是什么   7  
  在项目管理领域,IPD(Integrated Product Development,集成产品开发)流程以其跨部门协作、高效决策和快速响应市场变化的特点,被众多企业视为提升竞争力的关键。然而,实践IPD流程并非易事,项目管理中的种种错误往往阻碍了其效果的充分发挥。本文旨在深入探讨如何在实施IPD流程时避免这些常见错误,...
IPD框架   7  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用