Получение версии Postgres с помощью PowerShell в Windows [dубликат]

Я в корпоративной среде (под управлением Debian Linux) и не устанавливал ее сам. Я обращаюсь к базам данных с помощью Navicat или phpPgAdmin (если это помогает). У меня также нет доступа к оболочке на сервере, на котором запущена база данных.

645
задан 1 March 2015 в 23:00

11 ответов

Использование 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
172
ответ дан 15 August 2018 в 16:17
  • 1
    Спасибо, SHOW server_version; очень удобен в сценариях, чтобы избежать необходимости синтаксического анализа в длинной строке SELECT version();. – vaab 2 June 2014 в 20:18
  • 2
    Большое спасибо. Люди не понимают, что для выдачи SQL-команд вам нужно знать хотя бы одну роль для подключения к базе данных. Но с postgres -V вам не нужно знать, чтобы подключиться к базе данных, чтобы узнать ее версию. – ychaouche 3 November 2014 в 12:19
  • 3
    Одна строка в CLI, предполагающая доступ суперпользователя: psql postgres -c "SHOW server_version" -t -A. -t удаляет заголовки, -A удаляет пробелы выравнивания. – Pocketsand 10 July 2017 в 19:58

В моем случае, дополняя ответ @ A-B-B, который отлично работает для меня, это следующее:

$ locate bin/postgres -- if not found, use "sudo updatedb" to update the index of locate command
/usr/lib/postgresql/9.0/bin/postgres -- local found
$ cd /usr/lib/postgresql/9.0/bin -- my local installation
$ sudo ./postgres -V
postgres (PostgreSQL) 9.0.23
3
ответ дан 15 August 2018 в 16:17

Не знаю, насколько это надежно, но вы можете получить два токена версии полностью:

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 этой командой.

1
ответ дан 15 August 2018 в 16:17

Если у вас есть доступ к оболочке на сервере (вопрос упоминает op, но у вас нет), то в системе debian / ubuntu

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.

2
ответ дан 15 August 2018 в 16:17
  • 1
    В качестве аналогичной идеи я выполнил $ yum list, чтобы убедиться, что установлены определенные пакеты Postgresql. – Patrick 21 June 2018 в 00:43
  • 2
    это хорошо работает. Не могли бы вы указать, как обновить с 9.6 до 10. на ubuntu 16.04 – kRazzy R 22 June 2018 в 22:30

Выполнить команду

psql -V

Где

V должен находиться в капитале.

33
ответ дан 15 August 2018 в 16:17
  • 1
    Это версия psql (клиент), не версия сервера Postgres . – a_horse_with_no_name 14 June 2017 в 16:45

Я считаю, что это то, что вы ищете,

Версия сервера:

pg_config --version

Версия клиента:

psql --version
386
ответ дан 15 August 2018 в 16:17
  • 1
    Благодаря! Это работает, когда доступ к оболочке доступен. К сожалению, в моем случае у меня нет такого доступа; Я обновил вопрос. – Highly Irregular 6 December 2012 в 04:47
  • 2
    Это показывает версию клиентского приложения psql, а не версию сервера базы данных. – Frank Heikens 6 December 2012 в 19:07
  • 3
    Это было точное совпадение для голосового ответа, когда я его проверил. Произошла какая-то маршрутизация, и вы правы сэр. Я оставлю это для людей, которые могут захотеть совершить ту же ошибку – user 6 December 2012 в 20:27
  • 4
    Иногда клиентская версия - это то, что вы хотите знать в любом случае. – Trejkaz 24 December 2013 в 10:31
  • 5
    Как замечает Фрэнк, это может обманывать. psql будет подключаться к любому процессу базы данных postmaster / postgres, и механизм базы данных может быть не такой же, как команда psql. – Ben Roberts 19 April 2014 в 09:34

Команда pg_config сообщит директорию, в которой установлены программы PostgreSQL (--bindir), расположение файлов C include (--includedir) и библиотек объектов (--libdir) и версия PostgreSQL (- -версия):

$ pg_config --version
PostgreSQL 9.3.6
8
ответ дан 15 August 2018 в 16:17

Если Select version() возвращается с Memo, попробуйте использовать команду следующим образом:

Select version::char(100) 

или

Select version::varchar(100)
1
ответ дан 15 August 2018 в 16:17
  • 1
    select version()::varchar(100); работал для меня, но был таким же, как version() – isaaclw 4 December 2013 в 01:45

в оболочке psql.exe, выполнить

\! psql -V
8
ответ дан 15 August 2018 в 16:17
  • 1
    Это даст ему версию клиента postgre. Я тонкий, что ОП запрашивает версию сервера sql. – SpKel 17 April 2018 в 18:23

Принятый ответ велик, но если вам нужно взаимодействовать программно с версией 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...
     */  

Дополнительная информация здесь и здесь.

12
ответ дан 15 August 2018 в 16:17

В моем случае

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

Надеюсь, что это поможет кому-то

8
ответ дан 15 August 2018 в 16:17

Другие вопросы по тегам:

Похожие вопросы: