时间:2021-07-01 10:21:17 帮助过:24人阅读
运行于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;