SQL--存储过程中嵌套游标的使用方法

    技术2022-07-11  104

    下面是我写的一个嵌套游标SQL语句,如有需要,可以参考

    CREATE PROCEDURE [dbo].[BATCH_INSERT_DATA] --传入TaskID @TaskID int AS BEGIN declare @name nvarchar(50),@code nvarchar(50) --声明第一个游标 declare p_cursor CURSOR for select personName,personCode from dbo.HR_Batch_Import_Person where TaskID=@TaskID SET NOCOUNT ON; --打开第一个游标 OPEN p_cursor fetch next from p_cursor into @name,@code --将人员名称,人员编码存入@name,@code --第一个游标的循环体 WHILE @@FETCH_STATUS =0 BEGIN --声明第二个游标 declare d_cursor CURSOR for select fatherTypeName,typeName,recordName,createTime,pageNum,note from dbo.HR_Batch_Import_T where TaskID=@TaskID --打开第二个游标 OPEN d_cursor declare @fatherTypeName nvarchar(50),@typeName nvarchar(50),@recordName nvarchar(50),@createTime datetime,@pageNum int,@note nvarchar(200) fetch next from d_cursor into @fatherTypeName,@typeName,@recordName,@createTime,@pageNum,@note --第二个由标的循环体 WHILE @@FETCH_STATUS =0 BEGIN ---------------- --需要的逻辑语句-- ---------------- **--用于第二个循环体循环,缺少将成为死循环** fetch next from d_cursor into @fatherTypeName,@typeName,@recordName,@createTime,@pageNum,@note END --关闭第二个游标 CLOSE d_cursor --释放第二个游标的资源 DEALLOCATE d_cursor **--用于第一个循环体循环,缺少将成为死循环** fetch next from p_cursor into @name,@code END --关闭第一个游标 CLOSE p_cursor --释放第一个游标资源 DEALLOCATE p_cursor END GO
    Processed: 0.011, SQL: 9