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

2024-11-06 08:35:00
admin
原创
216
摘要:问题描述:我在公司环境中(运行 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展开片段

相关推荐
  政府信创国产化的10大政策解读一、信创国产化的背景与意义信创国产化,即信息技术应用创新国产化,是当前中国信息技术领域的一个重要发展方向。其核心在于通过自主研发和创新,实现信息技术应用的自主可控,减少对外部技术的依赖,并规避潜在的技术制裁和风险。随着全球信息技术竞争的加剧,以及某些国家对中国在科技领域的打压,信创国产化显...
工程项目管理   1565  
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   1354  
  信创国产芯片作为信息技术创新的核心领域,对于推动国家自主可控生态建设具有至关重要的意义。在全球科技竞争日益激烈的背景下,实现信息技术的自主可控,摆脱对国外技术的依赖,已成为保障国家信息安全和产业可持续发展的关键。国产芯片作为信创产业的基石,其发展水平直接影响着整个信创生态的构建与完善。通过不断提升国产芯片的技术实力、产...
国产信创系统   21  
  信创生态建设旨在实现信息技术领域的自主创新和安全可控,涵盖了从硬件到软件的全产业链。随着数字化转型的加速,信创生态建设的重要性日益凸显,它不仅关乎国家的信息安全,更是推动产业升级和经济高质量发展的关键力量。然而,在推进信创生态建设的过程中,面临着诸多复杂且严峻的挑战,需要深入剖析并寻找切实可行的解决方案。技术创新难题技...
信创操作系统   27  
  信创产业作为国家信息技术创新发展的重要领域,对于保障国家信息安全、推动产业升级具有关键意义。而国产芯片作为信创产业的核心基石,其研发进展备受关注。在信创国产芯片的研发征程中,面临着诸多复杂且艰巨的难点,这些难点犹如一道道关卡,阻碍着国产芯片的快速发展。然而,科研人员和相关企业并未退缩,积极探索并提出了一系列切实可行的解...
国产化替代产品目录   28  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

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

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

内置subversion和git源码管理

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

免费试用