【问题标题】:Which version of PostgreSQL am I running?我运行的是哪个版本的 PostgreSQL?
【发布时间】:2012-11-23 21:32:55
【问题描述】:

我在一个公司环境中(运行 Debian Linux)并且没有自己安装它。我使用 Navicat 或 phpPgAdmin 访问数据库(如果有帮助的话)。我也没有对运行数据库的服务器的 shell 访问权限。

【问题讨论】:

    标签: linux database postgresql


    【解决方案1】:

    从 PostgreSQL 运行此查询:

    SELECT version();
    

    【讨论】:

    • 在我的 Ubuntu 终端中没有结果
    • @Timo,这是一个通过 PostgreSQL 运行的查询。这可以通过 pgAdmin 或任何其他运行查询的机制来完成。您是否尝试从 Ubuntu shell 运行它? (这行不通)
    • 这也可以使用psql -c 'SELECT version();'从命令行运行
    • 您可以直接从 bash 中运行,指定 postgres 数据库,如下所示:psql postgres -c 'SELECT version();'
    • @Frank H. 使用:sudo -u postgres psql postgres -c 'SELECT version()' | grep PostgreSQL 应该可以让您摆脱“角色‘用户名’不存在”。
    【解决方案2】:

    我相信这就是你要找的,

    服务器版本:

    pg_config --version
    

    客户端版本:

    psql --version
    

    【讨论】:

    • 谢谢!这适用于 shell 访问可用时。不幸的是,就我而言,我没有那种访问权限;我已经更新了问题。
    • 有时客户端版本是您无论如何都想知道的。
    • 正如弗兰克所说,这可能具有欺骗性。 psql 将连接到正在运行的任何 postmaster/postgres 数据库进程,并且数据库引擎可能与 psql 命令的版本不同。
    • 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
    【解决方案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,因为postmasterpostgres 的已弃用别名。

    客户端版本:

    如相关,login as 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 -V
    psql (PostgreSQL) 9.2.9
    

    【讨论】:

    • 谢谢!,SHOW server_version; 在脚本中非常方便,可以避免解析 SELECT version(); 的长字符串。
    • 非常感谢。人们没有意识到,要发出 SQL 命令,您必须至少知道一个角色才能连接到数据库。但是使用 postgres -V 你不必知道连接到数据库就可以知道它的版本。
    • CLI 中的一行假设超级用户访问:psql postgres -c "SHOW server_version" -t -A-t 删除标题,-A 删除对齐空白。
    • 特别感谢SHOW server_version_num,它对不平等很方便。
    【解决方案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 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...
           */  
      

      更多信息herehere

      【讨论】:

        【解决方案6】:

        执行命令

        psql -V
        

        在哪里

        V 必须大写。

        【讨论】:

        【解决方案7】:

        在 shell psql.exe 中,执行

        \! psql -V
        

        【讨论】:

        • 这将为他提供 postgre 客户端的版本。我认为 OP 要求提供 sql server 版本。
        【解决方案8】:

        使用pgadmin4 可以通过双击服务器> server_name_here > 属性选项卡> 版本来查看:

        3.5 版:

        版本 4.1、4.5:

        【讨论】:

        • 没看到。使用 pgadmin 4 版本 4.1。
        • @faintsignal 添加了 pgadmin4 v4.1 的屏幕截图,版本跳转发生得非常快。
        • 哦,我的错。我以为您正在右键单击服务器,这会导致不同的“属性”对话框。谢谢!
        【解决方案9】:

        一个简单的方法是在终端输入psql --version来检查版本

        【讨论】:

        • 请注意,这只会告诉您客户端版本,这很可能与服务器不同。请参阅@simhumileco 对规范方式的回答。
        【解决方案10】:

        就我而言

        $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)
        

        希望对大家有所帮助

        【讨论】:

          【解决方案11】:

          pg_config 命令将报告 PostgreSQL 程序的安装目录 (--bindir)、C 包含文件 (--includedir) 和目标代码库 (--libdir) 的位置以及 PostgreSQL 的版本 (- -版本):

          $ pg_config --version
          PostgreSQL 9.3.6
          

          【讨论】:

            【解决方案12】:

            使用VERSION特殊变量

            $psql -c "\echo :VERSION"
            

            【讨论】:

            • \ 命令由 psql 客户端提供。这不是您可以放入其他客户端的 SQL 语句。问题是关于 Navicat 等,它们不支持这种语法。
            【解决方案13】:

            如果你已经在使用 for 工具(使用 DBeaver)连接 PostgreSQL,它将如下所示:

            【讨论】:

              【解决方案14】:

              如果您在 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: &lt;version&gt; 是安装的 postgres 包版本。

              【讨论】:

              • 出于类似的想法,我运行$ yum list 以查看某些 Postgresql 包已安装。
              • 这很好用。您能否说明如何在 ubuntu 16.04 上从 9.6 升级到 10。
              【解决方案15】:

              检查PostgreSQL Database Version的有用查询

              bash-4.1$ psql
              postgres=# SELECT version();
              postgres=# SHOW server_version;
              

              检查 PostgreSQL 客户端版本。

              bash-4.1$ psql --version
              psql (PostgreSQL) 12.1
              

              【讨论】:

                【解决方案16】:

                不知道这有多可靠,但你可以完全自动获得两个版本令牌:

                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 服务器的版本
                【解决方案17】:

                对于当前版本的 PgAdmin:在撰写本文时为 4.16。

                1. 选择您需要其版本的数据库。
                2. 单击属性选项卡 右侧窗格。

                请看下面的截图:

                【讨论】:

                  【解决方案18】:
                  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"
                  

                  查看本指南here 以获得完整说明

                  【讨论】:

                    【解决方案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)
                    

                    在我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(); 查询获得的版本相同。

                    【讨论】:

                      【解决方案20】:

                      如果Select version() 带有备忘录返回,请尝试以这种方式使用命令:

                      Select version::char(100) 
                      

                      Select version::varchar(100)
                      

                      【讨论】:

                      • select version()::varchar(100); 为我工作,但与 version() 相同
                      猜你喜欢
                      • 2017-09-06
                      • 1970-01-01
                      • 1970-01-01
                      • 1970-01-01
                      • 2013-04-05
                      • 2019-11-26
                      • 1970-01-01
                      • 2012-01-15
                      相关资源
                      最近更新 更多