游标删除多个表里脏数据的方法

2022-05-24 0 980

第一种方法:

复制代码 代码如下:

CREATE proc [dbo].[delAllRecord]
as
declare @tableName nvarchar(255)
declare @Sql nvarchar(255)

Declare curTable Cursor
        for select Table_Name from information_schema.tables where TABLE_TYPE=’BASE TABLE’
Open curTable
Fetch Next From curTable Into @tableName

WHILE(@@FETCH_STATUS = 0)
        BEGIN
                set @Sql = N’delete from ‘+@tableName
                exec sp_executesql @sql
                Fetch Next From curTable Into @tableName
        end
CLOSE curTable
DEALLOCATE curTable

第二种方法:

复制代码 代码如下:

–declare test_cursor cursor scroll for

–select id,table_name from dbo.section_type

–open test_cursor

–declare @id int

–declare @table_name nvarchar(50)

–while @@fetch_status=0

–begin

–fetch next from test_cursor into @id,@table_name

–print @id

–print @table_name

–end

–close test_cursor

–deallocate test_cursor

 

–删除projectrangtree的脏数据

delete from projectrangtree where deleteversion>0

delete from projectrangtree where type=3 and parentid not in(select id from projectrangtree where type=2)

delete from projectrangtree where type=4 and parentid not in(select id from projectrangtree where type=3)

delete from projectrangtree where type=5 and parentid not in(select id from projectrangtree where type=4)

 

–删除section_settings的脏数据

delete from section_settings where parent_prj_tree_id not in(select id from projectrangtree)

 

–删除各个表里的测点

declare @table_name varchar(50)

declare @sql nvarchar(500)–此处要注意,声明的长度一定要够

–declare @measuring_point_id nvarchar(500)

declare del_cursor cursor scroll for

select table_name from section_type

open del_cursor

fetch next from del_cursor into @table_name

–print @table_name

while (@@fetch_status=0)

begin

–print quotename(@table_name)

–set @measuring_point_id=’select measuring_point_id from ‘+quotename(@table_name)

–exec sp_executesql @measuring_point_id

set @sql = ‘delete from ‘+ quotename(@table_name) +’ where measuring_point_id not in(select id from measuring_point_setting)’            

exec sp_executesql @sql

–delete from @table_name where measuring_point_id not in (select id from measuring_point_setting)

fetch next from del_cursor into @table_name

end

close del_cursor

deallocate del_cursor
 

–delete from (select talbe_name from section_type) where measuring_point_id not in (select id from measuring_point_setting)

免责声明:
1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

NICE源码网 MsSql 游标删除多个表里脏数据的方法 https://www.niceym.com/61242.html