Którą wersję PostgreSQL używam?


1025

Jestem w środowisku korporacyjnym (z systemem Debian Linux) i sam go nie instalowałem. Dostęp do baz danych uzyskuję za pomocą Navicat lub phpPgAdmin (jeśli to pomaga). Nie mam również dostępu shellowego do serwera z bazą danych.

Odpowiedzi:


1644

Uruchom to zapytanie z PostgreSQL:

SELECT version();

4
Brak wyników w moim przypadku w terminalu na Ubuntu
Timo

22
@ Timo, jest to zapytanie uruchamiane przez PostgreSQL. Można to zrobić za pomocą pgAdmin lub dowolnego innego mechanizmu uruchamiania zapytania. Czy próbowałeś uruchomić go z powłoki Ubuntu? (to nie zadziała)
Wysoce nieregularny

41
Można to również uruchomić z wiersza poleceń za pomocąpsql -c 'SELECT version();'
Aarona Leleviera

3
Możesz uruchomić bezpośrednio z basha, podając db postgres w następujący sposób:psql postgres -c 'SELECT version();'
thathashd

22
@Frank H. Używanie: sudo -u postgres psql postgres -c 'SELECT version()' | grep PostgreSQLpowinno sprawić, że przeszłość „rola„ nazwa użytkownika ”nie istnieje”.
Marcus Junius Brutus

550

Wierzę, że tego właśnie szukasz

Wersja serwera:

pg_config --version

Wersja klienta:

psql --version

1
Dzięki! Działa to, gdy dostęp do powłoki jest dostępny. Niestety w moim przypadku nie mam tego dostępu; Zaktualizowałem pytanie.
Wysoce nieregularny

3
Czasami i tak jest wersja klienta.
Trejkaz

12
Jak zauważa Frank, może to być mylące. psql połączy się z każdym uruchomionym procesem bazy danych postmaster / postgres, a silnik bazy danych może nie być tej samej wersji co polecenie psql.
Ben Roberts,

2
pg_config --versionmoże wprowadzać w błąd, np. jeśli uaktualnisz serwer Ubuntu i nie uruchomisz pg_upgradecluster, pg_config wyświetli nową wersję zamiast tej, której nadal używasz.
Marius Gedminas

tylko działa to dla mnie: pg_config --version Polecenie: psql --versionnie działa, skarży się na to: dyld: Library not loaded: /usr/local/opt/readline/lib/libreadline.7.dylib Referenced from: /usr/local/bin/psql Reason: image not found
RLD

217

Za pomocą CLI:

Wersja serwera:

$ 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

Jeśli masz więcej niż jedną instalację PostgreSQL lub otrzymujesz postgres: command not foundbłąd „ ”:

$ 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

Jeśli locateto nie pomoże, spróbuj 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

Chociaż postmastermożna go również użyć zamiast postgres, postgrespreferowane jest używanie, ponieważ postmasterjest to przestarzały alias postgres.

Wersja klienta:

W razie potrzeby zaloguj się jakopostgres .

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

Jeśli masz więcej niż jedną instalację 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

Za pomocą SQL:

Wersja serwera:

=> 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

Jeśli bardziej ciekawy, spróbuj => SHOW all;.

Wersja klienta:

Za to, co jest warte, można wykonać polecenie powłoki, psqlaby wyświetlić wersję klienta psqlpliku wykonywalnego na ścieżce. Zauważ, że bieg psqlmoże potencjalnie różnić się od tego na ścieżce.

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

12
Dziękuję! SHOW server_version;Jest to bardzo przydatne w skryptach, aby uniknąć konieczności parsowania długiego ciągu SELECT version();.
vaab

Wielkie dzięki. Ludzie nie zdają sobie sprawy, że aby wydawać polecenia SQL, musisz znać przynajmniej jedną rolę, aby połączyć się z bazą danych. Ale dzięki postgres -V nie musisz wiedzieć, aby połączyć się z bazą danych, aby poznać jej wersję.
ychaouche

Jedna linia w CLI zakładając dostępu administratora: psql postgres -c "SHOW server_version" -t -A. -tusuwa nagłówki, -Ausuwa białe znaki wyrównania.
Pocketsand

SHOW server_version_numW szczególności dziękuję , co jest przydatne w przypadku nierówności.
eswald

63

Jeśli używasz CLI i jesteś postgres użytkownikiem , możesz to zrobić:

psql -c "SELECT version();"


Możliwe wyjście :

                                                         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

Przyjęta odpowiedź jest świetna, ale jeśli potrzebujesz programowo wchodzić w interakcje z wersją PostgreSQL, może lepiej:

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

Zwróci wersję serwera jako liczbę całkowitą. W ten sposób testowana jest wersja serwera w źródle PostgreSQL , np .:

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

Więcej informacji tutaj i tutaj .


36

Wykonaj polecenie

psql -V

Gdzie

V musi być w formie kapitału.


8
To jest psqlwersja (kliencka), a nie wersja serwera Postgres .
a_horse_w_na_name

Do recenzentów : jeśli odpowiedź jest nieprawidłowa, ale jest odpowiedzią (jak sugeruje komentarz), nie zalecamy usuwania: zgłoś głos! Zobacz na przykład: „ Robisz to źle: prośba o zdrowie psychiczne w kolejce postów niskiej jakości ” i „ Kiedy odpowiedź odpowiada na złe pytanie, czy to nie jest odpowiedź? ”. To jest odpowiedź. Możesz się z tym nie zgodzić, ale jest to próba odpowiedzi na pytanie.
Wai Ha Lee


12

Prostym sposobem jest sprawdzenie wersji poprzez wpisanie psql --versionterminala


3
Zauważ, że powie ci to tylko wersja klienta, która może być całkiem inna niż serwer. Zobacz odpowiedź @ simhumileco na kanoniczny sposób.
jstr

12

Używanie pgadmin4go można zobaczyć, klikając dwukrotnie opcję Serwery> nazwa_serwera> karta Właściwości> Wersja:

Wersja 3.5:

pgadmin4 pokaż wersję postgres.  Serwery> nazwa_serwera> Właściwości> Wersja

Wersja 4.1, 4.5:

wprowadź opis zdjęcia tutaj


Nie widzę tego Korzystanie z pgadmin 4 wersja 4.1.
faintsignal

1
@faintsignal dodał zrzut ekranu dla pgadmin4 v4.1, ten skok wersjonowania nastąpił dość szybko.
jmunsch

1
Och, mój błąd. Myślałem, że kliknąłeś prawym przyciskiem myszy serwer, co prowadzi do innego okna dialogowego „Właściwości”. Dzięki!
faintsignal

9

Komenda pg_config zgłosi katalog, w którym zainstalowane są programy PostgreSQL (--bindir), lokalizację plików włączeń C (--includedir) i bibliotek kodów obiektowych (--libdir) oraz wersję PostgreSQL (--version) :

$ pg_config --version
PostgreSQL 9.3.6

8

W moim przypadku

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

Mam nadzieję, że to komuś pomoże


4

Jeśli masz dostęp shellowy do serwera (pytanie wspomina, że ​​op nie ma, ale jeśli masz,) w systemie debian / ubuntu

sudo apt-cache policy postgresql

który wyświetli zainstalowaną wersję,

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

gdzie Installed: <version>jest zainstalowaną wersją pakietu postgres.


1
Jako podobny pomysł pobiegłem, $ yum listaby zobaczyć, że niektóre pakiety Postgresql zostały zainstalowane.
Patrick,

to działa dobrze. Czy możesz podać sposób aktualizacji z wersji 9.6 do wersji 10. na Ubuntu 16.04
kRazzy R


2

Nie wiem, na ile jest to wiarygodne, ale możesz uzyskać dwa tokeny wersji w pełni automatycznie:

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

Możesz więc budować ścieżki do plików binarnych:

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

Po prostu zamień 9.2 na to polecenie.


psql --versionzwraca wersję psqlklienta, a nie wersję serwera Postgres
a_horse_with_no_name

1

Dla bieżącej wersji PgAdmin: 4.16 w momencie pisania.

  1. Wybierz bazę danych DB, której wersji potrzebujesz.
  2. Kliknij kartę właściwości w prawym okienku.

Zobacz zrzut ekranu poniżej: PGAdmin 4.16 pokazuje wersję DB 10.10


0

Jeśli Select version()wraca z notatką, spróbuj użyć polecenia w ten sposób:

Select version::char(100) 

lub

Select version::varchar(100)

2
select version()::varchar(100);pracował dla mnie, ale był taki sam jakversion()
isaaclw
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.