我正在使用新版本的 PostgreSql 更新 Linux 服务器,当我浏览表格时,我在 phpPgAdmin 中出现错误消息。

运行 Apache 2.4.41、PHP 7.3.11 的 Ubuntu 18.04.3 LTS 服务器,当我更新到 PostgreSQL 12.0 phpPgAdmin 7.12.0 时出现错误。使用 PostgreSQL 11.5 和 phpPgAdmin 5.6 我没有这个问题。

我希望使用 phpPgAdmin 将存储在表中的数据可视化,但实际输出是:

    SQL error:
ERROR:  column «relhasoids» does not exist
LINE 1: SELECT relhasoids FROM pg_catalog.pg_class WHERE relname='pr...

    In statement:
SELECT relhasoids FROM pg_catalog.pg_class WHERE relname='product'
            AND relnamespace = (SELECT oid FROM pg_catalog.pg_namespace WHERE nspname='public')

最佳答案

编辑文件 /usr/share/phppgadmin/classes/database/Postgres.php 并评论 line 1045 to line 1054 错误消失:

function hasObjectID($table) {
    $c_schema = $this->_schema;
    $this->clean($c_schema);
    $this->clean($table);
/*
    $sql = "SELECT relhasoids FROM pg_catalog.pg_class WHERE relname='{$table}'
        AND relnamespace = (SELECT oid FROM pg_catalog.pg_namespace WHERE nspname='{$c_schema}')";

    $rs = $this->selectSet($sql);
    if ($rs->recordCount() != 1) return null;
    else {
        $rs->fields['relhasoids'] = $this->phpBool($rs->fields['relhasoids']);
        return $rs->fields['relhasoids'];
    } */
}

10-04 10:10