2

PHP 7 では、Interbase モジュールの操作方法が少し変更されたようです。

PHP 5.6 の同じコードは問題なく動作します。

Interbase/Firebird データベースへの 1 つの開いているリンクがあり、同じデータベースへの別のリンクを開くと、最初のリンクは閉じられます。

コードの一例は次のとおりです。

$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

php7 の Interbase モジュールには、この問題を引き起こしている新しいオプションがありますか?

4

1 に答える 1

0

これは php-7.0 のバグです。

少し前にバージョン 7.2.16 で修正され、それ以前のバージョンでも修正された場合。

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

于 2016-06-28T08:42:51.347 に答える