清华大佬耗费三个月吐血整理的几百G的资源,免费分享!....>>>
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;