として宣言された変数を含む SQL スクリプトがDECLARE @@var_1 as bigint
あり、それには while ループが含まれていますWHILE @@FETCH_STATUS
。 NPoco を使用してそのようなスクリプトを実行すると、Must declare the scalar variable "@FETCH_STATUS".
どのように解決できますか? という例外が発生します。主な目的は、SQL Server と ORACLE の両方で同じスクリプトを使用することです。
DECLARE @@LayerId bigint;
DECLARE @@DId as bigint;
DECLARE @@DataSegment as CURSOR;
DECLARE @@IterationNo as int;
IF OBJECT_ID(N'DataSegment') IS NOT NULL AND
OBJECT_ID(N'Layer') IS NOT NULL
BEGIN
SET @@IterationNo = 0;
SET @@DataSegment = CURSOR FORWARD_ONLY FOR
SELECT Id FROM DataSegment
OPEN @@DataSegment;
FETCH NEXT FROM @@DataSegment INTO @@DId
WHILE @@FETCH_STATUS = 0
BEGIN
SET @@IterationNo = @@IterationNo + 1;
SET @@LayerId = 9;
PRINT @@LayerId;
--Insert parent RouteVersion
INSERT INTO Layer Values(@@LayerId,'Migration',6,'Trace',
'Route','TEST', @@DId, NULL, @@LayerId, 9)
Print 'Iter is ' ;
Print @@IterationNo
--fetch next
FETCH NEXT FROM @@DataSegment INTO @@DId;
END
CLOSE @@DataSegment;
DEALLOCATE @@DataSegment;
END
前もって感謝します。