PHP 7.1 — Ошибка с несколькими подключениями к Interbase с PHP 7

Похоже, PHP 7 немного изменил способ работы с модулем Interbase.

Тот же код на PHP 5.6 работает без нареканий.

Если у вас есть одна открытая ссылка на базу данных Interbase / Firebird, и вы открываете другой один к той же базе данных первая ссылка это закрыто.

Одним из примеров кода может быть:

$conx = ibase_pconnect(DB_HOST . ":" . DB_NAME,DB_USER,DB_PWD,DB_CHARACTER) or die(ibase_errcode() . ' ' . ibase_errmsg());

$conx2 = ibase_pconnect(DB_HOST . ":" . DB_NAME,DB_USER,DB_PWD,DB_CHARACTER) or die(ibase_errcode() . ' ' . ibase_errmsg());

$sql = 'SELECT something from somewhere';

$query = ibase_query($conx, $sql);

while ($row = ibase_fetch_assoc($query)) {
echo $row['something'];
}

DB_xxx — это переменные с пользователями, паролем, базой данных.

Результат тот же, если вместо ibase_pconnect мы пишем ibase_connect

Если вы запустите этот код, вы ничего не получите, и в журнале страниц вы увидите что-то вроде:

supplied resource is not a valid Firebird/InterBase link resource in ....

ibase_fetch_assoc(): Dynamic SQL Error SQL error code = -504 Invalid cursor reference Cursor is not open ....

Если мы удалим строку с $ conx2, все будет отлично работать.

На моем php.ini у меня есть это (точно так же, как на PHP 5.6):

ibase.allow_persistent = 1

; Maximum number of persistent links.  -1 means no limit.
ibase.max_persistent = -1

; Maximum number of links (persistent + non-persistent).  -1 means no limit.
ibase.max_links = -1

В модуле Interbase для php7 появилась новая опция, которая порождает эту проблему?

2

Решение

Это ошибка php-7.0, которая сегодня еще не исправлена

https://bugs.php.net/bug.php?id=72175

🙁

0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]