実行しているPostgreSQLのバージョンは?


1027

私は(Debian Linuxを実行している)企業環境にいて、自分でインストールしませんでした。NavicatまたはphpPgAdminを使用してデータベースにアクセスします(役立つ場合)。また、データベースを実行しているサーバーにシェルアクセスできません。

回答:


1646

PostgreSQLからこのクエリを実行します。

SELECT version();

4
Ubuntuのターミナルで私のケースに結果がない
Timo

23
@Timo、これはPostgreSQLを介して実行されるクエリです。これは、pgAdmin、またはクエリを実行するための他のメカニズムを介して行うことができます。Ubuntuシェルから実行しようとしていましたか?(これは機能しません)
非常に不規則14

41
これはまたしてコマンドラインから実行することができますpsql -c 'SELECT version();'
アーロンLelevier

3
あなたは次のようにDBのpostgresを指定してのbashから直接実行することができますpsql postgres -c 'SELECT version();'
thathashd

22
@フランクH.使用:sudo -u postgres psql postgres -c 'SELECT version()' | grep PostgreSQL「ロール 'ユーザー名'は存在しません」を回避する必要があります。
Marcus Junius Brutus

550

これはあなたが探しているものだと思います、

サーバーのバージョン:

pg_config --version

クライアントのバージョン:

psql --version

1
ありがとう!これは、シェルアクセスが利用可能な場合に機能します。残念ながら、私の場合、そのアクセス権はありません。質問を更新しました。
12:47に非常に不規則な

3
とにかく、クライアントのバージョンは、とにかく知りたいものです。
Trejkaz 2013

12
フランクが指摘するように、これはだまされる可能性があります。psqlは、実行中のpostmaster / postgresデータベースプロセスに接続します。データベースエンジンは、psqlコマンドと同じバージョンではない可能性があります。
ベンロバーツ

2
pg_config --versionたとえば、Ubuntuサーバーをアップグレードしてを実行しない場合pg_upgradecluster、pg_configはまだ使用しているバージョンではなく新しいバージョンを表示します。
Marius Gedminas

これは私にとってはpg_config --versionpsql --versiondyld: Library not loaded: /usr/local/opt/readline/lib/libreadline.7.dylib Referenced from: /usr/local/bin/psql Reason: image not found
うまくいき

217

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;

クライアントのバージョン:

価値があることについては、シェルコマンドを実行して、パス内の実行可能ファイルのpsqlクライアントバージョンを表示できpsqlます。実行psql中は、パス内のものとは異なる可能性があることに注意してください。

=> \! psql -V
psql (PostgreSQL) 9.2.9

12
ありがとう!SHOW server_version;は、の長い文字列を解析する必要がないように、スクリプトで非常に便利ですSELECT version();
vaab

どうもありがとう。SQLコマンドを発行するには、データベースに接続するために少なくとも1つのロールを知っている必要があることに人々は気づいていません。しかし、postgres -Vを使用すると、データベースに接続してそのバージョンを知る必要はありません。
ychaouche 2014年

スーパーユーザーアクセスを想定したCLIの1行:psql postgres -c "SHOW server_version" -t -A-tヘッダーを-A削除し、配置の空白を削除します。
Pocketsand 2017

SHOW server_version_num特に、不平等に役立つので、ありがとうございます。
eswald

64

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)

37

受け入れられた答えは素晴らしいですが、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...
     */  

詳細はこちらこちら


36

コマンドを実行する

psql -V

どこ

Vは大文字でなければなりません。


8
これはpsql(クライアント)バージョンであり、Postgres サーバーのバージョンではありません
a_horse_with_no_name 2017年

レビュー:downvote:答えは間違っているが、(コメントが示すように)答えであれば、削除をお勧めしません!たとえば、「あなたは間違っている:低品質の投稿キューに正気を求める嘆願」と「答えが間違った質問に答えたとき、それは答えではないのか?」を参照してください。これが答えです。あなたはそれに同意しないかもしれませんが、それは質問に答えようとする試みです。
Wai Ha Lee


12

簡単な方法はpsql --version、ターミナルに入力してバージョンを確認することです


3
これはクライアントのバージョンを通知するだけであり、サーバーとはかなり異なる可能性があることに注意してください。標準的な方法については、@ simhumilecoの回答を参照してください。
jstr

12

使用する pgadmin4するには、[サーバー]> [server_name_here]> [プロパティ]タブ> [バージョン]をダブルクリックします。

バージョン3.5:

pgadmin4はpostgresのバージョンを表示します。 サーバー> server_name>プロパティ>バージョン

バージョン4.1、4.5:

ここに画像の説明を入力してください


見ないで。pgadmin 4バージョン4.1を使用します。
かすかな信号

1
@faintsignalはpgadmin4 v4.1のスクリーンショットを追加しました。バージョン管理のジャンプは非常に迅速に行われました。
jmunsch

1
ああ、私の間違い。サーバーを右クリックして、別の[プロパティ]ダイアログが表示されると思いました。ありがとう!
かすかな信号

9

pg_configコマンドは、PostgreSQLプログラムがインストールされているディレクトリ(--bindir)、Cインクルードファイルの場所(--includedir)、オブジェクトコードライブラリ(--libdir)、およびPostgreSQLのバージョン(--version)を報告します:

$ pg_config --version
PostgreSQL 9.3.6

8

私の場合

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

それが誰かを助けることを願って


4

debian / ubuntuシステムでサーバーにシェルアクセスできる場合(質問には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パッケージのバージョンです。


1
同様のアイデアとして、$ yum list特定のPostgresqlパッケージがインストールされていることを確認しました。
Patrick

これはうまくいきます。ubuntu 16.04で9.6から10にアップグレードする方法を教えてください
kRazzy R


2

これの信頼性がわからない場合でも、バージョンの2つのトークンを完全に自動的に取得できます。

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 --versionPostgresサーバーのバージョンではなくpsqlクライアントのバージョンを返します
a_horse_with_no_name

1

PgAdminの現在のバージョン:執筆時点では4.16。

  1. バージョンが必要なDBを選択します。
  2. 右ペインのプロパティタブをクリックします。

下のスクリーンショットを参照してください。 DBバージョン10.10を示すPGAdmin 4.16


0

Select version()メモで戻る場合は、次のようにコマンドを使用してみてください。

Select version::char(100) 

または

Select version::varchar(100)

2
select version()::varchar(100);私のために働いたが、同じだったversion()
isaaclw
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.