【发布时间】:2012-11-23 21:32:55
【问题描述】:
我在一个公司环境中(运行 Debian Linux)并且没有自己安装它。我使用 Navicat 或 phpPgAdmin 访问数据库(如果有帮助的话)。我也没有对运行数据库的服务器的 shell 访问权限。
【问题讨论】:
标签: linux database postgresql
我在一个公司环境中(运行 Debian Linux)并且没有自己安装它。我使用 Navicat 或 phpPgAdmin 访问数据库(如果有帮助的话)。我也没有对运行数据库的服务器的 shell 访问权限。
【问题讨论】:
标签: linux database postgresql
从 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 可能会产生误导,例如如果您升级 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
$ 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 的已弃用别名。
如相关,login as 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 中执行一个shell 命令,以在路径中显示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 source 中测试服务器版本的方式,例如:
/*
* 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 服务器的版本。
在 shell psql.exe 中,执行
\! psql -V
【讨论】:
一个简单的方法是在终端输入psql --version来检查版本
【讨论】:
就我而言
$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 包含文件 (--includedir) 和目标代码库 (--libdir) 的位置以及 PostgreSQL 的版本 (- -版本):
$ pg_config --version
PostgreSQL 9.3.6
【讨论】:
使用VERSION特殊变量
$psql -c "\echo :VERSION"
【讨论】:
如果您在 debian/ubuntu 系统上具有对服务器的 shell 访问权限(问题提到 op 没有,但如果您有)
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 包已安装。
检查PostgreSQL Database Version的有用查询
bash-4.1$ psql
postgres=# SELECT version();
postgres=# SHOW server_version;
检查 PostgreSQL 客户端版本。
bash-4.1$ psql --version
psql (PostgreSQL) 12.1
【讨论】:
不知道这有多可靠,但你可以完全自动获得两个版本令牌:
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 服务器的版本
postgres -V
客户:
psql -V
postgres=# select version();
或来自 cli:
psql -c "SELECT version();"
VERSION特殊变量
以 postgres 用户身份登录:sudo su - postgres
然后:
psql -c "\echo :VERSION"
查看本指南here 以获得完整说明
【讨论】:
这是一个相当古老的问题,有很多很好的答案。我发现从版本 12 开始,只需调用客户端就可以告诉我我需要知道的内容,但我在服务器的 shell 上运行它们。下面的示例与输出。
当我使用第 12 版时:
$ sudo su postgres -c "psql"
psql (12.8 (Ubuntu 12.8-0ubuntu0.20.04.1))
因为客户端和服务器都是 12 版,所以我读到这里。
在我将 Ubuntu 从 20.04 升级到 21.04 之后:
$ sudo su postgres -c "psql"
psql (13.4 (Ubuntu 13.4-0ubuntu0.21.04.1), server 12.8 (Ubuntu 12.8-0ubuntu0.20.04.1))
正如我确认的那样,它清楚地告诉我客户端是 13 版,但服务器仍然是 12 版:
$ pg_lsclusters
Ver Cluster Port Status Owner Data directory Log file
12 main 5432 online postgres /var/lib/postgresql/12/main /var/log/postgresql/postgresql-12-main.log
顺便说一下,在这个阶段注意这个误导性的结果:
$ pg_config --version
PostgreSQL 13.4 (Ubuntu 13.4-0ubuntu0.21.04.1)
在我upgraded 到版本 14 之后:
$ sudo su postgres -c "psql"
psql (14.0 (Ubuntu 14.0-1.pgdg21.04+1))
Type "help" for help.
postgres=#
再次,我将其解释为客户端和服务器都在版本 14 上,再次确认:
$ pg_lsclusters
Ver Cluster Port Status Owner Data directory Log file
12 main 5432 down,binaries_missing postgres /var/lib/postgresql/12/main /var/log/postgresql/postgresql-12-main.log
14 main 5433 online postgres /var/lib/postgresql/14/main /var/log/postgresql/postgresql-14-main.log
顺便说一下,这个版本与运行SELECT version(); 查询获得的版本相同。
【讨论】:
如果Select version() 带有备忘录返回,请尝试以这种方式使用命令:
Select version::char(100)
或
Select version::varchar(100)
【讨论】:
select version()::varchar(100); 为我工作,但与 version() 相同