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