0

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
4

1 に答える 1

0

.17はうまくいきました。Microsoft の Web インストーラーから入手できるバージョンは遅れており、php.net から最新のものをインストールすることは考えていませんでした。ありがとう。

+1 ハクレ

于 2012-10-15T14:34:17.647 に答える