运行于SQLServer 2008 SQL Server create procedure proc_deptasdeclare @cursor cursor,@id varchar(50),@pid varchar(100)beginset @cursor = cursorforselect deparet_id, parent_deparet_id from dbo.tb_department_tree order by sequence;open @cursorf
运行于SQLServer 2008
SQL Server
create procedure proc_dept
as
declare @cursor cursor,
@id varchar(50),
@pid varchar(100)
begin
set @cursor = cursor
for
select deparet_id, parent_deparet_id from dbo.tb_department_tree order by sequence;
open @cursor
fetch next from @cursor into @id, @pid;
while(@@FETCH_STATUS = 0)
begin
if(@pid is null)
begin
update tb_department_tree set scope = @id, tlevel = 1, tpath = @id where deparet_id = @id;
end
else
begin
update tb_department_tree set tlevel = (select tlevel from tb_department_tree where deparet_id = @pid)+1, tpath = (select tpath from tb_department_tree where deparet_id = @pid)+'-'+@id where deparet_id = @id;
update tb_department_tree set scope =(select SUBSTRING(tpath, 0, CHARINDEX('-',tpath, 0)) from tb_department_tree where deparet_id = @id) from tb_department_tree where deparet_id = @id;
end;
fetch next from @cursor into @id, @pid;
end;
close @cursor;
end;
exec proc_dept;
drop procedure proc_dept;
本文原创发布php中文网,转载请注明出处,感谢您的尊重!