游标删除多个表里脏数据的方法
第一种方法:
代码如下:
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)
相关推荐
数据库工具开发 2020-06-26
wqbala 2020-05-05
简单的快乐 2020-03-06
zhaojp0 2019-12-27
踩风火轮的乌龟 2019-11-01
GavinZhera 2019-10-26
nimeijian 2019-10-20
GodLong 2010-09-14
chenjiawei 2011-07-13
chenshurui 2019-07-01
89510293 2019-06-30
讨厌什么变成什么 2019-06-30
oradbm 2016-06-13
whutjiajiao 2019-06-29
大胡子抽雪茄 2019-06-29
确实比较男 2012-03-29
frank0 2011-01-06
petterlu 2010-07-22
especialjie 2010-04-13