Que versão do PostgreSQL estou a correr?

Estou em um ambiente corporativo (executando Debian Linux) e não o instalei eu mesmo. Eu acedo às bases de dados usando Navicat ou phpPgAdmin (se isso ajudar). Também não tenho acesso ao servidor a correr a base de dados.

 678
Author: A-B-B, 2012-12-06

11 answers

Execute esta pesquisa a partir do PostgreSQL:

SELECT version();
 1036
Author: Highly Irregular, 2017-10-24 03:42:02
Acho que é disto que estás à procura.

Versão do Servidor:

pg_config --version

Versão cliente:

psql --version
 406
Author: chhantyal, 2016-02-25 13:58:01

Usando CLI:

Versão do servidor:

$ 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

Se tiver mais do que uma instalação de PostgreSQL, ou se tiver obtido o erro de " 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

Se locate não ajudar, tente 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

Embora postmaster também possa ser usado em vez de postgres, a utilização de postgres é preferível porque postmaster é um nome falso de postgres.

Versão cliente:

Conforme relevante, autenticar-se como postgres.

$ psql -V  # Or --version
psql (PostgreSQL) 9.6.1

Se tiver mais de um instalação do 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

Usando SQL:

Versão do servidor:

=> 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
Se for mais curioso, tente.

Versão cliente:

Para que conste, um comando shell pode ser executado dentro de {[17] } para mostrar a versão Cliente do executável psql no path. Note que a execução psql pode ser potencialmente diferente da do caminho.

=> \! psql -V
psql (PostgreSQL) 9.2.9
 175
Author: A-B-B, 2016-12-09 05:15:17

Executar o comando

psql -V

Onde

V deve estar em capital.

 33
Author: vipin cp, 2016-08-27 16:18:34

Com casca psql.exe, execute

\! psql -V
 14
Author: Diego Santa Cruz Mendezú, 2018-04-09 07:24:38

A resposta aceite é óptima, mas se precisar de interagir programaticamente com a versão Pós-Gresql talvez seja melhor fazer:

SELECT current_setting('server_version_num'); -- Returns 90603 (9.6.3)
-- Or using SHOW command:
SHOW server_version_num; -- Returns 90603 too

Irá devolver a versão do servidor como um inteiro. É assim que a versão server é testada na fonte PostgreSQL, por exemplo:

/*
 * 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...
     */  

Mais informações Aqui e Aqui .

 12
Author: Michel Milezzi, 2017-09-25 20:51:35

No meu caso

$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)
Espero que ajude alguém.
 8
Author: Vikas Hardia, 2014-07-18 10:29:04

O comando pg_config irá comunicar o diretório onde o PostgreSQL programas estão instalados (--bindir), a localização dos ficheiros de inclusão C (--includedir) e o objeto de bibliotecas de código (--libdir), e a versão do PostgreSQL (--version):

$ pg_config --version
PostgreSQL 9.3.6
 8
Author: Donato, 2015-04-23 06:22:48

Se você tem acesso shell ao servidor (a pergunta menciona op não tem, mas no caso de você ter,) em um sistema debian/ubuntu

sudo apt-cache policy postgresql

Que irá emitir a versão instalada,

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

Onde o Installed: <version> é a versão instalada do pacote postgres.

 2
Author: All Іѕ Vаиітy, 2018-03-25 21:20:44

Se Select version() retorna com Memo tente usar o comando desta forma:

Select version::char(100) 

Ou

Select version::varchar(100)
 1
Author: aTa, 2013-08-05 05:25:18

Não sei se isto é confiável, mas você pode obter dois tokens da versão totalmente automaticamente:

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

Para que possas construir caminhos para binários:

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

Apenas substitua o 9.2 por este comando.

 1
Author: Alexey Petrenko, 2014-10-20 11:21:41