PDO クエリの結果をフェッチしようとすると、エラーが発生します。コラムの内容に絞ったのですが、なぜこうなるのか、どうすれば直せるのかわかりません。エラー ログには何も記録されていないため、これは典型的な PHP エラーではありません。実際、それは PHP を完全にクラッシュさせていると思います。問題が何であるかについてのアイデアはありますか?
注: DB 変数は、ODBC への PDO 接続です。(MSSQL に行く)
$query = $Z->DB->query("SELECT TOP 1 id, ticket, typeid, issued, comment, privatecomment FROM Handheld_IncomingTickets WHERE processed is null ORDER BY issued asc");
// No error.
if (!$query->execute()) {
$moreData = false;
echo dump($query->errorInfo()) ." ".__FILE__." at Line: ".__LINE__;
break;
}
// No error.
$record = $query->fetch(PDO::FETCH_ASSOC);
// ERROR!
これは、500 エラーの原因となったレコードの 1 つのコメント欄の内容です。これは単なるテストデータです。コメント列には、本番環境では $_POST 変数のダンプはありませんが、なぜそれが重要なのか混乱しています。このような値をすべて消去することはできますが、問題の原因を突き止めなければ、有効なデータでこれが再び発生しないとは確信できません。
array ( 'act' => 'push', 'ticket' => '35-0191', 'ticket_int' => '191', 'vehicleid' => 'null', 'plate' => '028RLS', 'platetypeid' => 'null', 'provid' => '9', 'makeid' => '1', 'typeid' => '1', 'colourid' => '1', 'year' => 'null', 'locationid' => 'null', 'permitno' => 'null', 'sempermitid' => 'null', 'tickettype' => 'null', 'issued' => '2012-10-02%2013%3A22%3A31', 'violationtypeid' => 'null', 'writer' => '17', 'fine' => 'null', 'towing' => '', 'comment' => '', 'privatecomment' => '', 'synced' => 'null', )
これは、サーバーのイベント ログに表示されるエラーです。
Faulting application name: php-cgi.exe, version: 5.3.12.0, time stamp: 0x4fa94d46
Faulting module name: php5.dll, version: 5.3.12.0, time stamp: 0x4fa94db5
Exception code: 0xc0000005
Fault offset: 0x0000c3b6
Faulting process id: 0x2a0
Faulting application start time: 0x01cdaadbbdc7fb98
Faulting application path: C:\Program Files (x86)\PHP\v5.3\php-cgi.exe
Faulting module path: C:\Program Files (x86)\PHP\v5.3\php5.dll
Report Id: fbc37d92-16ce-11e2-9dcf-ca21ba90502f