如何在T-SQL中删除默认值或类似约束?

Fra*_*ger 66 sql t-sql default constraints

我知道语法:

ALTER TABLE [TheTable] DROP CONSTRAINT [TheDefaultConstraint]
Run Code Online (Sandbox Code Playgroud)

但是当我不知道它的名字时,如何删除默认约束?(也就是说,它是在CREATE TABLE时间自动生成的.)

Pol*_*rch 62

您可以使用此代码自动执行此操作:

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)
Run Code Online (Sandbox Code Playgroud)

只需更换<MYTABLENAME><MYCOLUMNNAME>酌情.

  • 我只是不明白为什么MS SQL不会自动删除默认约束. (7认同)
  • 对于懒惰的人(以及Microsoft的SQL Server开发人员),为了向这个答案致敬,用`CREATE PROCEDURE dbo.DropColumnDefaultOrConstraint @tableName VARCHAR(MAX),@ columnName VARCHAR(MAX)AS替换前两行然后换行`BEGIN `和`END`并使用`EXEC DropColumnDefaultOrConstraint'tablename','columnname';` (5认同)

adr*_*nks 47

如果要手动执行此操作,可以使用Management Studio查找它(在表中的"约束"节点下).

要使用SQL来做到这一点:

  • 如果约束是默认约束,您可以使用sys.default_constraints它来查找它:

    SELECT OBJECT_NAME(parent_object_id) AS TableName, name AS ConstraintName
    FROM sys.default_constraints ORDER BY TableName, ConstraintName
    
    Run Code Online (Sandbox Code Playgroud)
  • 如果您正在寻找其他约束(检查,唯一,外键,默认,主键),您可以使用sysconstraints:

    SELECT OBJECT_NAME(id) AS TableName, OBJECT_NAME(constid) AS ConstraintName
    FROM sysconstraints ORDER BY TableName, ConstraintName
    
    Run Code Online (Sandbox Code Playgroud)

您没有说明您使用的是哪个版本的SQL Server.以上是关于SQL 2005和SQL 2008的工作.