手机
当前位置:查字典教程网 >编程开发 >mssql数据库 >游标删除多个表里脏数据的方法
游标删除多个表里脏数据的方法
摘要:第一种方法:复制代码代码如下:CREATEproc[dbo].[delAllRecord]asdeclare@tableNamenvarch...

第一种方法:

复制代码 代码如下:

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)

【游标删除多个表里脏数据的方法】相关文章:

SqlServer2008误操作数据(delete或者update)后恢复数据的方法

SQL Server 海量数据导入的最快方法

SQL SERVER 2008 无法附加数据库的解决方法

复制SqlServer数据库的方法

一个过滤重复数据的 SQL 语句

删除SQL数据库中事务日志方法

SQL删除重复数据只保留一条

SQL Server把单个用户转换成多个用户的方法

SQL 合并多行记录的方法总汇

如何强制删除或恢复SQLServer正在使用的数据库

精品推荐
分类导航