Я нахожусь в корпоративной среде (использую Debian Linux) и не установил его сам. Я получаю доступ к базам данных с помощью Navicat или phpPgAdmin (если это помогает). У меня также нет доступа к серверу, на котором работает база данных.
Я нахожусь в корпоративной среде (использую Debian Linux) и не установил его сам. Я получаю доступ к базам данных с помощью Navicat или phpPgAdmin (если это помогает). У меня также нет доступа к серверу, на котором работает база данных.
Ответы:
Запустите этот запрос из PostgreSQL:
SELECT version();
psql -c 'SELECT version();'
psql postgres -c 'SELECT version();'
sudo -u postgres psql postgres -c 'SELECT version()' | grep PostgreSQL
должно пройти мимо вас "роль" имя пользователя "не существует".
Я считаю, что это то, что вы ищете,
Версия сервера:
pg_config --version
Версия клиента:
psql --version
pg_config --version
может вводить в заблуждение, например, если вы pg_upgradecluster
обновляете сервер Ubuntu и не запускаете , 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
$ 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
=> 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
SHOW server_version;
Это очень удобно в скриптах, чтобы избежать разбора длинной строки SELECT version();
.
psql postgres -c "SHOW server_version" -t -A
. -t
удаляет заголовки, -A
удаляет пробелы выравнивания.
SHOW server_version_num
в частности, что удобно для неравенства.
Если вы используете 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)
Принятый ответ хорош, но если вам нужно программно взаимодействовать с версией 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 -V
куда
V должно быть в столице.
psql
(клиентская) версия, а не версия сервера Postgres .
в оболочке psql.exe выполните
\! psql -V
Используя pgadmin4
его можно увидеть с помощью двойного щелчка Серверы> server_name_here> вкладка Свойства> Версия:
Версия 3.5:
Версия 4.1, 4.5:
В моем случае
$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)
Надеюсь, это поможет кому-то
Если у вас есть доступ к серверу через оболочку (вопрос упоминает, что 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.
$ yum list
чтобы увидеть, что были установлены определенные пакеты Postgresql.
Не знаю, насколько это надежно, но вы можете получить два токена версии полностью автоматически:
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
Для текущей версии PgAdmin: 4.16 на момент написания.