在 oracle 中,我可以发出 DROP TABLE ... 级联约束,它不会抱怨 FK 等。
T-SQL 中是否有等价物?
对于那些希望获得更普遍适用的答案的人
这将找到约束,删除它,然后是列
感谢并投票给 Tim Lentine如何找到默认约束的名称作为开始。
Declare @sql VarChar(255)
Declare @tableName Varchar(255)
Declare @columnName VarChar(255)
Select @tableName = 'MyTableName'
Select @columnName = 'MyColumnName'
select @sql = o.[name] from sysobjects o
inner join syscolumns c
on o.id = c.cdefault
inner join sysobjects t
on c.id = t.id
where o.xtype = 'd'
and t.name = @tableName
and c.name = @columnName
if @sql is not null
begin
select @sql = 'Alter Table ' + @tableName + ' Drop Constraint ' + @sql + ' Alter Table ' + @tablename + ' Drop Column ' + @columnName
exec(@sql)
end
不,在 SSMS 中右键单击表格,然后选择“将表格作为脚本”,然后选择“拖放到”,然后选择“新窗口”、“文件...”或“剪贴板”,它会生成一个包含所有必要滴 FK 等。