php 7 与 Interbase 的多个连接错误
Bug with multiple connections to Interbase with php 7
似乎 PHP7 改变了使用 Interbase 模块的方式。
相同代码在 PHP 5.6 上运行完美。
如果你有一个打开 link 到一个 Interbase/Firebird 数据库并且你打开 另一个 一个到同一个数据库第一个 link 它是已关闭。
一个代码示例可以是:
$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_connect
而不是 ibase_pconnect 结果是一样的
如果您 运行 该代码您将什么也得不到,并且在页面日志中您会看到如下内容:
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
php7 的 Interbase 模块有一个新选项,它会产生这个问题?
这是一个 php-7.0 错误。
If 已在 7.2.16 版本上修复,在较低版本中也已修复。
似乎 PHP7 改变了使用 Interbase 模块的方式。
相同代码在 PHP 5.6 上运行完美。
如果你有一个打开 link 到一个 Interbase/Firebird 数据库并且你打开 另一个 一个到同一个数据库第一个 link 它是已关闭。
一个代码示例可以是:
$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_connect
而不是 ibase_pconnect 结果是一样的如果您 运行 该代码您将什么也得不到,并且在页面日志中您会看到如下内容:
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
php7 的 Interbase 模块有一个新选项,它会产生这个问题?
这是一个 php-7.0 错误。
If 已在 7.2.16 版本上修复,在较低版本中也已修复。