Яку версію PostgreSQL я запускаю?


1025

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

Відповіді:


1644

Запустіть цей запит з PostgreSQL:

SELECT version();

4
Немає результату в моєму випадку в терміналі на Ubuntu
Тімо,

22
@Timo, це запит, який потрібно запустити через PostgreSQL. Це можна зробити через pgAdmin або будь-який інший механізм запуску запиту. Ви намагалися запустити його з оболонки Ubuntu? (це не спрацює)
Сильно нерегулярний

41
Сюди також можна psql -c 'SELECT version();'
запустити

3
Ви можете бігти прямо з bash, вказавши postgres db так:psql postgres -c 'SELECT version();'
thathashd

22
@Frank H. Використання: sudo -u postgres psql postgres -c 'SELECT version()' | grep PostgreSQLповинно отримати минуле "роль" ім'я користувача "не існує".
Маркус Юній Брут

550

Я вважаю, що це те, що ви шукаєте,

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

pg_config --version

Версія клієнта:

psql --version

1
Дякую! Це працює, коли доступ до оболонки доступний. На жаль, у моєму випадку я не маю такого доступу; Я оновив питання.
сильно нерегулярний

3
Іноді клієнтська версія - це те, про що ви хочете знати.
Трежказ

12
Як зазначає Франк, це може бути оманливим. psql підключиться до будь-якого процесу роботи з базою даних postmaster / postgres, і двигун бази даних може бути не такою ж версією, як команда psql.
Бен Робертс

2
pg_config --versionможе ввести в оману, наприклад, якщо ви оновите сервер Ubuntu і не запустите pg_upgradecluster, pg_config покаже нову версію замість тієї, яку ви все ще використовуєте.
Маріус Гедмінас

тільки це працює для мене: pg_config --version Команда: psql --versionне працює, скаржиться на це: dyld: Library not loaded: /usr/local/opt/readline/lib/libreadline.7.dylib Referenced from: /usr/local/bin/psql Reason: image not found
RLD

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 ви повинні знати хоча б одну роль для підключення до бази даних. Але з postgres -V вам не потрібно знати, щоб підключатися до бази даних, щоб знати її версію.
ychaouche

Один рядок в CLI за умови доступу суперкористувача psql postgres -c "SHOW server_version" -t -A. -tвидаляє заголовки, -Aвидаляє пробіл вирівнювання.
Pocketsand

Дякую за те SHOW server_version_num, що зручно для нерівностей.
eswald

63

Якщо ви користуєтесь 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

Для рецензентів : якщо відповідь неправильна, але відповідь (як випливає з коментаря), не рекомендуйте видаляти: downvote! Дивіться, наприклад, " Ви робите це неправильно: Заклик поваги в черзі з низькою якістю повідомлень " та " Коли відповідь відповідає на неправильне запитання, це не відповідь? ". Це відповідь. Ви можете не погодитися з цим, але це спроба відповісти на питання.
Вай Ха Лі


12

Простий спосіб - перевірити версію, ввівши psql --versionтермінал


3
Зауважте, що це розповість лише про клієнтську версію, яка, можливо, може відрізнятися від сервера. Дивіться відповідь @ simhumileco щодо канонічного шляху.
jstr

12

Використовуючи pgadmin4його, можна побачити, двічі клацнувши Сервери> Ім'я_сервера_тук> Вкладка Властивості> Версія:

Версія 3.5:

pgadmin4 показати постгресову версію.  Сервери> ім'я_сервера> Властивості> Версія

Версія 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

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 встановлені.
Патрік

це добре працює.
Скажіть,


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 --versionповертає версію psqlклієнта, а не версію сервера Postgres
a_horse_with_no_name

1

Для поточної версії PgAdmin: 4.16 під час написання.

  1. Виберіть БД, версія якої вам потрібна.
  2. Клацніть на вкладці властивостей у правій області.

Дивіться знімок екрана нижче: PGAdmin 4.16, що показує версію БД 10.10


0

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

Select version::char(100) 

або

Select version::varchar(100)

2
select version()::varchar(100);працював на мене, але був таким самим, якversion()
isaaclw
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.