7

SQL Server 2005 のテーブルに計算列を追加した後、次のメッセージが表示されINSERTます。PHP 経由 (PDO を使用) のみで、SQL Server Managment Studio で正常に動作しています。

すべてが正しいことを確認するために、SQL Server プロファイラーでトレースをセットアップし、INSERT ステートメントをコピーして SQL Server Managment Studio に貼り付けました。SSMS では問題なく動作しましたが、PHP では引き続き失敗します。

連絡先の追加エラー: SQLSTATE[HY000]: 一般的なエラー: 1934 一般的な SQL Server エラー: SQL Server からのメッセージを確認してください [1934] (重大度 16) [(null)]

4

3 に答える 3

11

問題はSETパラメータに関係していたことが判明しました。Hereから取得した以下のコードを使用しました。SQL Server Management Studio (挿入が機能した場所) で設定されたオプションを特定するため。次に、insert ステートメントの前にそれぞれを exec に配置すると、再び機能するようになりました。すべてのオプションを保持する必要はなかったので、機能させるために必要なオプションを以下に示します。

DECLARE @options INT
SELECT @options = @@OPTIONS

PRINT @options
IF ( (1 & @options) = 1 ) PRINT 'DISABLE_DEF_CNST_CHK' 
IF ( (2 & @options) = 2 ) PRINT 'IMPLICIT_TRANSACTIONS' 
IF ( (4 & @options) = 4 ) PRINT 'CURSOR_CLOSE_ON_COMMIT' 
IF ( (8 & @options) = 8 ) PRINT 'ANSI_WARNINGS' 
IF ( (16 & @options) = 16 ) PRINT 'ANSI_PADDING' 
IF ( (32 & @options) = 32 ) PRINT 'ANSI_NULLS' 
IF ( (64 & @options) = 64 ) PRINT 'ARITHABORT' 
IF ( (128 & @options) = 128 ) PRINT 'ARITHIGNORE'
IF ( (256 & @options) = 256 ) PRINT 'QUOTED_IDENTIFIER' 
IF ( (512 & @options) = 512 ) PRINT 'NOCOUNT' 
IF ( (1024 & @options) = 1024 ) PRINT 'ANSI_NULL_DFLT_ON' 
IF ( (2048 & @options) = 2048 ) PRINT 'ANSI_NULL_DFLT_OFF' 
IF ( (4096 & @options) = 4096 ) PRINT 'CONCAT_NULL_YIELDS_NULL' 
IF ( (8192 & @options) = 8192 ) PRINT 'NUMERIC_ROUNDABORT' 
IF ( (16384 & @options) = 16384 ) PRINT 'XACT_ABORT'

最終的に必要になったオプションは次のとおりです。

$dbPDO->exec("SET ANSI_WARNINGS ON");                                                                               
$dbPDO->exec("SET ANSI_PADDING ON");
$dbPDO->exec("SET ANSI_NULLS ON");
$dbPDO->exec("SET QUOTED_IDENTIFIER ON");
$dbPDO->exec("SET CONCAT_NULL_YIELDS_NULL ON");

更新: FK 制約により、次のエラーが発生したようです。上記もこのエラーを修正しました。

SQLSTATE[HY000]: 一般的なエラー: 8624 一般的な SQL Server エラー: SQL Server からのメッセージを確認してください [8624] (重大度 16) [(null)]

于 2013-04-17T07:35:55.827 に答える