2

プロシージャの最後に元の状態に戻すことができるように、NOCOUNTステータスを保存しようとしていますが、Incorrect syntax near 'NOCOUNT'.エラーが発生するだけです。

私は何が間違っているのですか?

IF @@OPTIONS & 512 <> 0     /* check original state of NOCOUNT */
      PRINT N'This user has SET NOCOUNT turned ON.';
  ELSE
      PRINT N'This user has SET NOCOUNT turned OFF.';

DECLARE @NCStat bit
    SET @NCStat = ( @@OPTIONS & 512 )   /* sets @NCStat to original state of NOCOUNT */

SET NOCOUNT ON ;

IF @@OPTIONS & 512 <> 0     /* verify state of NOCOUNT */
      PRINT N'This user has SET NOCOUNT turned ON.';
  ELSE
      PRINT N'This user has SET NOCOUNT turned OFF.';

PRINT N'NCStat = ' + cast(@NCStat as nvarchar) ;        /* verify value of @NCStat */

/* line 23 */  SET NOCOUNT  @NCStat ;       /* return NOCOUNT to original state */

IF @@OPTIONS & 512 <> 0     /* verify state of NOCOUNT */
      PRINT N'This user has SET NOCOUNT turned ON.';
  ELSE
      PRINT N'This user has SET NOCOUNT turned OFF.';
GO

23行目がコメントアウトされている場合、他のすべての行は正常に機能しますが、23行目は上記のエラーを示します。

4

1 に答える 1

3

変数を使用して設定することはできませんNOCOUNT

/* line 23 */  SET NOCOUNT  @NCStat ; /* not legal syntax */

代わりにこれを行います:

/* line 23 */
if @NCStat = 1
    SET NOCOUNT ON
else
    SET NOCOUNT OFF
于 2013-03-17T23:56:39.710 に答える