Ошибка с несколькими подключениями к 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 имеет новую опцию, из-за которой возникает эта проблема?


person NetVicious    schedule 05.05.2016    source источник
comment
Вполне может быть, что это ошибка в версии ext/interbase для PHP 7. Очень немногие используют это расширение, поэтому оно не совсем хорошо протестировано. Можете ли вы зарегистрировать ошибку на bugs.php.net?   -  person NikiC    schedule 08.05.2016
comment
В частности, я не думаю, что эта строка верна: lxr .php.net/xref/PHP_MASTER/ext/interbase/interbase.c#943 Вероятно, этот zend_list_close должен быть zend_list_delete, иначе он просто всегда будет уничтожать ресурс.   -  person NikiC    schedule 08.05.2016
comment
Привет, NIkiC, я использую Ubuntu 16.04 LTS, в которой используется PHP 7.0.4. На bugs.php.net написано, что если я не использую последнюю версию (7.0.7, я должен обновиться, прежде чем публиковать ошибку). Я отправил сообщение об ошибке в систему отслеживания ошибок Ubuntu в тот же день, когда написал здесь: bugs.launchpad.net/ubuntu/+source/php7.0/+bug/1578600   -  person NetVicious    schedule 09.05.2016
comment
Привет, NikiC, глядя на источник и ваш профиль, кажется, что ошибка в последней версии php, поэтому я создал ошибку в php bugtracker, как вы сказали. Спасибо. bugs.php.net/bug.php?id=72175   -  person NetVicious    schedule 09.05.2016


Ответы (1)


Это ошибка php-7.0.

Если было исправлено некоторое время назад в версии 7.2.16, а также исправлено в более ранних версиях.

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

person NetVicious    schedule 28.06.2016