PHP Conference Japan 2024

pg_version

(PHP 5, PHP 7, PHP 8)

pg_version返回一个包含客户端、协议和服务器版本(如果可用)的数组

描述

pg_version(?PgSql\Connection $connection = null): array

pg_version() 返回一个包含客户端、协议和服务器版本的数组。如果 PHP 使用 PostgreSQL 7.4 或更高版本编译,则协议和服务器版本才可用。

有关更详细的服务器信息,请使用 pg_parameter_status()

参数

connection

一个 PgSql\Connection 实例。当 connectionnull 时,将使用默认连接。默认连接是 pg_connect()pg_pconnect() 最后建立的连接。

警告

从 PHP 8.1.0 开始,使用默认连接已弃用。

返回值

返回一个包含 clientprotocolserver 键和值(如果可用)的数组。

变更日志

版本 描述
8.1.0 现在,connection 参数需要一个 PgSql\Connection 实例;以前需要一个 resource
8.0.0 connection 现在可以为 null。

示例

示例 #1 pg_version() 示例

<?php
$dbconn
= pg_connect("host=localhost port=5432 dbname=mary")
or die(
"Could not connect");

$v = pg_version($dbconn);

echo
$v['client'];
?>

以上示例将输出

7.4

参见

添加注释

用户贡献的注释 2 条注释

live627
4 年前
此函数对我来说的完整输出是

array(13) {
["client"]=>
string(5) "9.6.9"
["protocol"]=>
int(3)
["server"]=>
string(4) "12.1"
["server_encoding"]=>
string(4) "UTF8"
["client_encoding"]=>
string(4) "UTF8"
["is_superuser"]=>
string(2) "on"
["session_authorization"]=>
string(8) "postgres"
["DateStyle"]=>
string(8) "ISO, MDY"
["IntervalStyle"]=>
string(8) "postgres"
["TimeZone"]=>
string(10) "US/Arizona"
["integer_datetimes"]=>
string(2) "on"
["standard_conforming_strings"]=>
string(2) "on"
["application_name"]=>
string(0) ""
}
mgchristensen
4 年前
我注意到 "protocol" 的数组元素似乎没有值,报告为

["protocol"]=> int(3)

而例如 "server" 的数组元素报告为(在我的特定情况下)

["server"]=> string(5) "10.12"

但是,调用 json_encode() 会得到

"protocol":3 and "server":"10.12"
To Top