我知道它的语法:
ALTER TABLE [TheTable] DROP CONSTRAINT [TheDefaultConstraint]
但是,当我不知道默认约束的名称时,如何删除它呢?(也就是说,它是在CREATE TABLE
时间自动生成的。)
发布于 2012-05-26 00:46:47
您可以使用以下代码自动完成此操作:
DECLARE @tableName VARCHAR(MAX) = '<MYTABLENAME>'
DECLARE @columnName VARCHAR(MAX) = '<MYCOLUMNAME>'
DECLARE @ConstraintName nvarchar(200)
SELECT @ConstraintName = Name
FROM SYS.DEFAULT_CONSTRAINTS
WHERE PARENT_OBJECT_ID = OBJECT_ID(@tableName)
AND PARENT_COLUMN_ID = (
SELECT column_id FROM sys.columns
WHERE NAME = @columnName AND object_id = OBJECT_ID(@tableName))
IF @ConstraintName IS NOT NULL
EXEC('ALTER TABLE '+@tableName+' DROP CONSTRAINT ' + @ConstraintName)
只需适当地替换<MYTABLENAME>
和<MYCOLUMNNAME>
即可。
发布于 2009-07-14 01:47:23
您可以通过sp_help表名找到约束的名称,然后按名称删除它。
或者,您也可以通过Management studio完成此操作。
发布于 2009-07-14 01:48:55
或者,您可以使用sys.check_constraints目录视图找到它。
https://stackoverflow.com/questions/1123060
复制相似问题