下面是我写的一个嵌套游标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