How do you drop a default value from a column in a table?

89,634

Solution 1

Its a default constraint, you need to perform a:

ALTER TABLE {TableName} 
DROP CONSTRAINT ConstraintName

If you didn't specify a name when you created the constraint, then SQL Server created one for you. You can use SQL Server Management Studio to find the constraint name by browsing to the table, opening its tree node, then opening the Constraints node.

If I remember correctly, the constraint will be named something along the lines of DF_SomeStuff_ColumnName.

EDIT: Josh W.'s answer contains a link to a SO question that shows you how to find the auto generated constraint name using SQL instead of using the Management Studio interface.

Solution 2

This is what I came up with (before seeing Josh W. answer, well actually I saw it but skimmed it so fast I misunderstood it):

declare @name nvarchar(100)
select @name = [name] from sys.objects where type = 'D' and parent_object_id = object_id('sometable')

if (@name is not null)
  begin
     exec ('alter table [sometable] drop constraint [' + @name +']')
  end

The advantage I have here is that I know that there is only one such constraint on the whole table. If there had been two, well I guess that is why you are supposed to name them ;).

(The issues is that that this is a modification made to 10 different customer databases, so there isn't one consistent name to put in a script)

Solution 3

If you not know of constraints name

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 = N'__ColumnName__'
                        AND object_id = OBJECT_ID(N'__TableName__'))
IF @ConstraintName IS NOT NULL
EXEC('ALTER TABLE __TableName__ DROP CONSTRAINT ' + @ConstraintName)

https://stackoverflow.com/a/13715343/2547164

Solution 4

select name from sys.default_constraints where name like '%first_3_chars_of_field_name%'

Find your constraint and use DROP CONSTRAINT to drop it. Or run a cursor/while loop to drop all similar defaults in the database.

Solution 5

If you are using SQL Server Management Studio this is pretty easy.

If there are several constraints associated with the table and you don't want to delete them all, right-click on the constraint and select "Script Constraint as -> CREATE to -> New Query Editor Window". This will show you the code that created the constraint including the column name and default value.

Then just right-click on the constraint you want to delete and select Delete.

Share:
89,634
Yishai
Author by

Yishai

Updated on July 05, 2022

Comments

  • Yishai
    Yishai almost 2 years

    How do you alter a column to remove the default value?

    The column was created with:

     ALTER table sometable Add somecolumn nchar(1) NOT NULL DEFAULT 'N'
    

    And then altered with:

     alter table sometable alter column somecolumn nchar(1) null
    

    That allows nulls, but the default value remains. How can you remove it?

  • Dan Rigby
    Dan Rigby almost 15 years
    Yeah, that becomes an issue for any large scale database roll out. What you end up having to do is force yourself to always name your constraints so that they're consistent across environments. Ex.: ALTER table sometable Add somecolumn nchar(1) NOT NULL CONSTRAINT DF_TableName_SomeColumn DEFAULT 'N'
  • AaA
    AaA about 10 years
    I believe your solution will not work on a table with multiple default values, it will remove the last one
  • MirrorBoy
    MirrorBoy over 6 years
    It doesn't work, because my constrains have name like 'DF_tableName_someLetters'
  • MirrorBoy
    MirrorBoy over 6 years
    If the table has some constrains to different columns it is necessary to filter by column name: declare @name nvarchar(100) select * from sys.objects o join sys.columns col on o.object_id = col.default_object_id where type = 'D' and parent_object_id = object_id('tablename') and col.name = 'columnname'
  • Warios
    Warios over 3 years
    you can obtain the name of the constraint using sp_help 'table_name' in sql server