如何将具有默认值的列添加到SQL Server 2000/SQL Server 2005中的现有表中?


当前回答

试试这个

ALTER TABLE Product
ADD ProductID INT NOT NULL DEFAULT(1)
GO

其他回答

添加可为空的列时,WITH VALUES将确保将特定的DEFAULT值应用于现有行:

ALTER TABLE table
ADD column BIT     -- Demonstration with NULL-able column added
CONSTRAINT Constraint_name DEFAULT 0 WITH VALUES

这可以通过以下代码完成。

CREATE TABLE TestTable
    (FirstCol INT NOT NULL)
    GO
    ------------------------------
    -- Option 1
    ------------------------------
    -- Adding New Column
    ALTER TABLE TestTable
    ADD SecondCol INT
    GO
    -- Updating it with Default
    UPDATE TestTable
    SET SecondCol = 0
    GO
    -- Alter
    ALTER TABLE TestTable
    ALTER COLUMN SecondCol INT NOT NULL
    GO

SQL Server+更改表+添加列+默认值uniqueidentifier

ALTER TABLE Product 
ADD ReferenceID uniqueidentifier not null 
default (cast(cast(0 as binary) as uniqueidentifier))

试试这个

ALTER TABLE Product
ADD ProductID INT NOT NULL DEFAULT(1)
GO

语法:

ALTER TABLE {TABLENAME} 
ADD {COLUMNNAME} {TYPE} {NULL|NOT NULL} 
CONSTRAINT {CONSTRAINT_NAME} DEFAULT {DEFAULT_VALUE}
WITH VALUES

例子:

ALTER TABLE SomeTable
        ADD SomeCol Bit NULL --Or NOT NULL.
 CONSTRAINT D_SomeTable_SomeCol --When Omitted a Default-Constraint Name is autogenerated.
    DEFAULT (0)--Optional Default-Constraint.
WITH VALUES --Add if Column is Nullable and you want the Default Value for Existing Records.

笔记:

可选约束名称:如果忽略CONSTRAINT D_SomeTable_SomeCol,则SQL Server将自动生成具有有趣名称的默认对照,如:DF__SomeTa__SomeC_4FB7FEF6

可选值声明:只有当列为空时,才需要WITH VALUES并且您希望将默认值用于现有记录。如果您的列不是NULL,那么它将自动使用默认值对于所有现有记录,无论是否指定WITH VALUES。

插入件如何使用默认约束:如果在SomeTable中插入一条记录,但未指定SomeCol的值,则它将默认为0。如果插入Record并将SomeCol的值指定为NULL(并且您的列允许为空),则将不使用默认约束,并且将插入NULL作为值。

笔记基于下面每个人的反馈。特别感谢:@Yatrix、@WalterStabosz、@YahooSerious和@StackMan的评论。