Какую версию PostgreSQL я запускаю?

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

11 ответов


запустите этот запрос из PostgreSQL:

SELECT version();

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

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

pg_config --version

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

psql --version

использование 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

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

psql -V

здесь

V должен быть в столице.


в оболочке psql.EXE-файл , выполняется

\! psql -V

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

Подробнее здесь и здесь.


в моем случае

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

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


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

$ pg_config --version
PostgreSQL 9.3.6

Если у вас есть доступ оболочки к серверу (вопрос упоминает, что 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.


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

Select version::char(100) 

или

Select version::varchar(100)

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

psql --version 2>&1 | tail -1 | awk '{print }' | sed 's/\./ /g' | awk '{print  "." }'

таким образом, вы можете создавать пути к двоичным файлам:

/usr/lib/postgresql/9.2/bin/postgres

просто замените 9.2 этой командой.