您现在的位置是:网站首页> 编程资料编程资料
游标删除多个表里脏数据的方法_MsSql_
2023-05-26
512人已围观
简介 游标删除多个表里脏数据的方法_MsSql_
第一种方法:
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)
相关内容
- SQL直接操作excel表(查询/导入/插入)_MsSql_
- mssql 高效的分页存储过程分享_MsSql_
- oracle,mysql,SqlServer三种数据库的分页查询的实例_MsSql_
- sql server 2012 数据库所有表里查找某字符串的方法_MsSql_
- SQLSERVER的排序问题结果不是想要的_MsSql_
- SqlServer数据库全角转换成半角_MsSql_
- 如何创建支持FILESTREAM的数据库示例探讨_MsSql_
- 通过sql存储过程发送邮件的方法_MsSql_
- 还原sql server数据库的处理方法_MsSql_
- sql脚本查询数据库表,数据,结构,约束等操作的方法_MsSql_
