您可能想要添加TRY....CATCH
,还需要初始化变量@sql。你也可以考虑提出你的错误。
declare @sql nvarchar(max)
set @sql = ''
SELECT @sql += N'
ALTER TABLE ' + QUOTENAME(OBJECT_SCHEMA_NAME(parent_object_id))
+ '.' + QUOTENAME(OBJECT_NAME(parent_object_id)) +
' DROP CONSTRAINT ' + QUOTENAME(name) + ';'
FROM sys.foreign_keys;
BEGIN TRY
EXEC sp_executesql @sql;
END TRY
BEGIN CATCH
DECLARE @ErrorMessage NVARCHAR(4000)
DECLARE @ErrorState INT
DECLARE @ErrorSeverity INT
--Obtain the error message, severity and state
SELECT @ErrorMessage = ERROR_MESSAGE(), @ErrorSeverity = ERROR_SEVERITY(), @ErrorState = ERROR_STATE()
--RAISERROR (@ErrorMessage, @ErrorSeverity, @ErrorState)
END CATCH
如果要在删除外键约束后立即删除表。
declare @sql nvarchar(max)
declare @sqlToDropTables nvarchar(max)
set @sqlToDropTables=''
set @sql = ''
SELECT @sqlToDropTables +=N' DROP TABLE ' + QUOTENAME(OBJECT_SCHEMA_NAME(parent_object_id))
+ '.'
+ QUOTENAME(OBJECT_NAME(parent_object_id))
+ ';'
FROM sys.foreign_keys;
SELECT @sql += N'
ALTER TABLE ' + QUOTENAME(OBJECT_SCHEMA_NAME(parent_object_id))
+ '.' + QUOTENAME(OBJECT_NAME(parent_object_id)) +
' DROP CONSTRAINT ' + QUOTENAME(name) + ';'
FROM sys.foreign_keys;
BEGIN TRY
EXEC sp_executesql @sql;
EXEC sp_executesql @sqlToDropTables
END TRY
BEGIN CATCH
DECLARE @ErrorMessage NVARCHAR(4000)
DECLARE @ErrorState INT
DECLARE @ErrorSeverity INT
--Obtain the error message, severity and state
SELECT @ErrorMessage = ERROR_MESSAGE(), @ErrorSeverity = ERROR_SEVERITY(), @ErrorState = ERROR_STATE()
--RAISERROR (@ErrorMessage, @ErrorSeverity, @ErrorState)
END CATCH
添加更多代码,如果要清理所有表,请包含引用对象,即 PK 表。
declare @sql nvarchar(max)
declare @sqlToDropTables nvarchar(max)
set @sqlToDropTables=''
set @sql = ''
SELECT @sqlToDropTables +=N' DROP TABLE ' + QUOTENAME(OBJECT_SCHEMA_NAME(parent_object_id))
+ '.'
+ QUOTENAME(OBJECT_NAME(parent_object_id))
+ ';'
+ 'DROP TABLE ' + QUOTENAME(OBJECT_SCHEMA_NAME(referenced_object_id))
+ '.'
+ QUOTENAME(OBJECT_NAME(referenced_object_id))
+ ';'
FROM sys.foreign_keys;
SELECT @sql += N'
ALTER TABLE ' + QUOTENAME(OBJECT_SCHEMA_NAME(parent_object_id))
+ '.' + QUOTENAME(OBJECT_NAME(parent_object_id)) +
' DROP CONSTRAINT ' + QUOTENAME(name) + ';'
FROM sys.foreign_keys;
BEGIN TRY
EXEC sp_executesql @sql;
EXEC sp_executesql @sqlToDropTables
END TRY
BEGIN CATCH
DECLARE @ErrorMessage NVARCHAR(4000)
DECLARE @ErrorState INT
DECLARE @ErrorSeverity INT
--Obtain the error message, severity and state
SELECT @ErrorMessage = ERROR_MESSAGE(), @ErrorSeverity = ERROR_SEVERITY(), @ErrorState = ERROR_STATE()
--RAISERROR (@ErrorMessage, @ErrorSeverity, @ErrorState)
END CATCH