(PHP 4 >= 4.3.0, PHP 5)
sybase_set_message_handler — サーバーでメッセージが発生した際にコールされるハンドラを指定する
この機能は PHP 7.0.0 で 削除 されました。
sybase_set_message_handler() は、 サーバーからのメッセージを処理するユーザー関数を設定します。グローバル関数の名前、 あるいはオブジェクトへの参照とメソッド名を保持する配列を指定します。
handler
ハンドラは、以下の 5 つの引数をこの順に受け取ります。
number, severity, state, line number そして description。
最初の 4 つは整数値で、最後は文字列です。関数が FALSE
を返した場合、PHP は通常のエラーメッセージを表示します。
link_identifier
リンクIDを省略した場合は、最後に開いたリンクを使います。
成功した場合に TRUE
を、失敗した場合に FALSE
を返します。
例1 sybase_set_message_handler() コールバック関数
<?php
function msg_handler($msgnumber, $severity, $state, $line, $text)
{
var_dump($msgnumber, $severity, $state, $line, $text);
}
sybase_set_message_handler('msg_handler');
?>
例2 クラスへの sybase_set_message_handler() コールバック
<?php
class Sybase {
function handler($msgnumber, $severity, $state, $line, $text)
{
var_dump($msgnumber, $severity, $state, $line, $text);
}
}
$sybase= new Sybase();
sybase_set_message_handler(array($sybase, 'handler'));
?>
例3 sybase_set_message_handler() が処理しないメッセージ
<?php
// この関数から FALSE を返すことは、それをこの関数では処理しないことを
// 意味します。エラーは警告として表示され、ハンドラが何も設定されていない
// 場合と同様に処理できます。
function msg_handler($msgnumber, $severity, $state, $line, $text)
{
if (257 == $msgnumber) {
return false;
}
var_dump($msgnumber, $severity, $state, $line, $text);
}
sybase_set_message_handler('msg_handler');
?>
注意: この関数は、Sybase の CT ライブラリインターフェイスでのみ使用可能で、DB ライブラリでは使用できません。