SQL新增修改表字段列的类型等
例如:
修改(列名前要有column关键字)
ALTER TABLE [USER] ALTER column [NAME] varchar(35) null
新增
ALTER TABLE [USER] ADD [PRICE]    numeric(18, 8) NULL  DEFAULT 0
通过更改、添加、除去列和约束,或者通过启⽤或禁⽤约束和触发器来更改表的定义。
语法
ALTER TABLE table
{ [ ALTER COLUMN column_name
{ new_data_type [ ( precision [ , scale ] ) ]
[ COLLATE < collation_name > ]
[ NULL | NOT NULL ]
| {ADD | DROP } ROWGUIDCOL }
]
| ADD
{ [ < column_definition > ]
| column_name AS computed_column_expression
} [ ,...n ]
| [ WITH CHECK | WITH NOCHECK ] ADD
{ < table_constraint > } [ ,...n ]
| DROP
{ [ CONSTRAINT ] constraint_name
| COLUMN column } [ ,...n ]
| { CHECK | NOCHECK } CONSTRAINT
{ ALL | constraint_name [ ,...n ] }
| { ENABLE | DISABLE } TRIGGER
{ ALL | trigger_name [ ,...n ] }
}
< column_definition > ::=
{ column_name data_type }
[ [ DEFAULT constant_expression ] [ WITH VALUES ]
| [ IDENTITY [ ( seed , increment ) [ NOT FOR REPLICATION ] ] ]
]
[ ROWGUIDCOL ]
[ COLLATE < collation_name > ]
[ < column_constraint > ] [ ...n ]
< column_constraint > ::=
[ CONSTRAINT constraint_name ]
{ [ NULL | NOT NULL ]
| [ { PRIMARY KEY | UNIQUE }
[ CLUSTERED | NONCLUSTERED ]
[ WITH FILLFACTOR = fillfactor ]
[ ON { filegroup | DEFAULT } ]
]
| [ [ FOREIGN KEY ]
REFERENCES ref_table [ ( ref_column ) ]
[ ON DELETE { CASCADE | NO ACTION } ]
[ ON UPDATE { CASCADE | NO ACTION } ]
[ NOT FOR REPLICATION ]
]
| CHECK [ NOT FOR REPLICATION ]
( logical_expression )
}
< table_constraint > ::=
[ CONSTRAINT constraint_name ]
{ [ { PRIMARY KEY | UNIQUE }
[ CLUSTERED | NONCLUSTERED ]
{ ( column [ ,...n ] ) }
[ WITH FILLFACTOR = fillfactor ]
[ ON { filegroup | DEFAULT } ]
]
|    FOREIGN KEY
[ ( column [ ,...n ] ) ]
REFERENCES ref_table [ ( ref_column [ ,...n ] ) ]
[ ON DELETE { CASCADE | NO ACTION } ]
[ ON UPDATE { CASCADE | NO ACTION } ]
[ NOT FOR REPLICATION ]
| DEFAULT constant_expression
[ FOR column ] [ WITH VALUES ]
|    CHECK [ NOT FOR REPLICATION ]
( search_conditions )
}
参数
table
是要更改的表的名称。如果表不在当前数据库中或者不属于当前⽤户所拥有,可以显式指定数据库和所有者。
ALTER COLUMN
指定要更改给定列。如果兼容级别是 65 或⼩于 65,将不允许使⽤ ALTER COLUMN。
要更改的列不能是:
数据类型为 text、image、ntext 或 timestamp 的列。
表的 ROWGUIDCOL 列。
计算列或⽤于计算列中的列。
被复制列。
⽤在索引中的列,除⾮该列数据类型是 varchar、nvarchar 或 varbinary,数据类型没有更改,⽽且新列⼤⼩等于或者⼤于旧列⼤⼩。
⽤在由 CREATE STATISTICS 语句创建的统计中的列。⾸先⽤ DROP STATISTICS 语句删除统计。由查询优化器⾃动⽣成的统计会由 ALTER COLUMN ⾃动除去。
⽤在 PRIMARY KEY 或 [FOREIGN KEY] REFERENCES 约束中的列。
⽤在 CHECK 或 UNIQUE 约束中的列,除⾮⽤在 CHECK 或 UNIQUE 约束中的可变长度列的长度允许更改。
有相关联的默认值的列,除⾮在不更改数据类型的情况下允许更改列的长度、精度或⼩数位数。
column_name
是要更改、添加或除去的列的名称。对于新列,如果数据类型为 timestamp,column_name 可以省略。对于 timestamp 数据类型的列,如果未指定 column_name,将使⽤名称 timestamp。
new_data_type
是要更改的列的新数据类型。要更改的列的 new_data_type 应符合下列准则:
原来的数据类型必须可以隐式转换为新数据类型。
new_data_type 类型不能为 timestamp。
对 ALTER COLUMN,ANSI 空默认值始终打开;如果没有指定,列将可为空。
对 ALTER COLUMN,ANSI 填充始终打开。
如果要更改的列是标识列,new_data_type 必须是⽀持标识属性的数据类型。
将忽略 SET ARITHABORT 的当前设置。ALTER TABLE 语句的⾏为如同 ARITHABORT 选项为 ON 时⼀样。
precision
是指定数据类型的精度。
scale
是指定数据类型的⼩数位数。有关有效⼩数位数值的更多信息,
COLLATE < collation_name >
为更改列指定新的排序规则。排序规则名称既可以是 Windows 排序规则名称,也可以是 SQL 排序规则名称。
COLLATE ⼦句只能⽤于更改数据类型为 char、varchar、text、nchar、nvarchar 和 ntext 的列的排序规则。如果未指定,则此列采⽤数据库的默认排序规则。
若满⾜下列条件,则 ALTER COLUMN 不能更改排序规则:
检查约束、外键约束或计算列引⽤了更改列。
在此列上创建了索引、统计或全⽂索引。更改列的排序规则时,该列上⾃动创建的统计将除去。
SCHEMABOUND 视图或函数引⽤了此列。
NULL | NOT NULL
指定该列是否可接受空值。不允许空值的列只有在指定了默认值的情况下,才能⽤ ALTER TABLE 语句向表中添加。添加到表中的新列要么允许空值,要么必须指定默认值。
如果新列允许空值,⽽且没有指定默认值,那么新列在表中每⼀⾏都包含空值。如果新列允许空值并且指定了新列的默认值,那么可以使⽤ WITH VALUES 选项在表中所有现有⾏的新列中存储默认值。
如果新列不允许空值,那么新列必须具有 DEFAULT 定义,⽽且新列的所有现有⾏中将⾃动装载该默认值。
可在 ALTER COLUMN 语句中指定 NULL 以使 NOT NULL 列允许空值,但 PRIMARY KEY 约束中的列除外。只有列中不包含空值时,ALTER COLUMN 中才可指定 NOT NULL。必须将空值更新为⾮空值后,才允许执⾏ ALTER COLUMN NOT NULL 语句,⽐如:
UPDATE MyTable SET NullCol = N'some_value' WHERE NullCol IS NULLALTER TABLE MyTable ALTER COLUMN NullCOl NVARCHAR(20) NOT NULL
如果 ALTER COLUMN 中指定了 NULL 或 NOT NULL,那么必须同时指定 new_data_type [(precision [, scale ])]。如果不更改数据类型、精度和⼩数位数,请指定列的这些值的当前值。
[ {ADD | DROP} ROWGUIDCOL ]
指定在指定列上添加或除去 ROWGUIDCOL 属性。ROWGUIDCOL 是⼀个关键字,表⽰列是⾏全局唯⼀标识符列。对于每个表只能指派⼀个 uniqueidentifier 列作为 ROWGUIDCOL 列。ROWGUIDCOL 属性只能指派给 uniqueidentifier 列。
ROWGUIDCOL 属性并不强制列中所存储值的唯⼀性。该属性也不会为插⼊到表中的新⾏⾃动⽣成值。若要为每列⽣成唯⼀值,那么或者在 INSERT 语句中使⽤ NEWID 函数,或者将 NEWID 函数指定为该列的默认值。
ADD
指定要添加⼀个或多个列定义、计算列定义或者表约束。
computed_column_expression
是⼀个定义计算列的值的表达式。计算列是并不物理地存储在表中的虚拟列,该列⽤表达式计算得出,该表达式使⽤同⼀表中的其它列。例如,计算列的定义可以是:cost AS price * qty。表达式可以是⾮计算列的列名、常量、函数、变量,也可以是⽤⼀个或多个运算符连接的上述元素的任意组合。表达式不能为⼦查询。
计算列可⽤于选择列表、WHERE ⼦句、ORDER BY 字句或其它任何可以使⽤常规表达式的位置,但下列情况除外:
计算列不能⽤作 DEFAULT 或 FOREIGN KEY 约束定义,也不能与 NOT NULL 约束定义⼀起使⽤。但是,如果计算列由具有确定性的表达式定义,并且索引列中允许计算结果的数据类型,则可将该列⽤作索引中的键列,或⽤作 PRIMARY KEY 或 UNIQUE 约束的⼀部分。
例如,如果表中有整数列 a 和 b,那么计算列 a+b 上可建⽴索引,⽽计算列 a+DATEPART(dd, GETDATE()) 上则不能,因为该值将在后续调⽤时更改。
计算列不能作为 INSERT 或 UPDATE 语句的⽬标。
说明由于表中计算列所⽤列中的各⾏可能有不同的值,所以计算列的每⼀⾏可能有不同的值。
n
是表⽰前⾯的项可重复 n 次的占位符。
WITH CHECK | WITH NOCHECK
指定表中的数据是否⽤新添加的或重新启⽤的 FOREIGN KEY 或 CHECK 约束进⾏验证。如果没有指定,对于新约束,假定为 WITH CHECK,对于重新启⽤的约束,假定为 WITH NOCHECK。
WITH CHECK 和 WITH NOCHECK ⼦句不能⽤于 PRIMARY KEY 和 UNIQUE 约束。
如果不想⽤新 CHECK 或 FOREIGN KEY 约束对现有数据进⾏验证,请⽤ WITH NOCHECK,除了个别情况,不建议这样使⽤。新约束将在以后的所有更新中⽣效。任何在添加约束时
由 WITH NOCHECK 抑制的约束违规都可能导致将来的更新失败,如果这些更新操作要更新的⾏中包含不符合约束条件的数据。
查询优化器不考虑⽤ WITH NOCHECK 定义的约束。将忽略这些约束,直到使⽤ ALTER TABLE table CHECK CONSTRAINT ALL语句重新启⽤这些约束为⽌。
DROP { [CONSTRAINT] constraint_name | COLUMN column_name }
指定从表中删除 constraint_name 或者 column_name。如果兼容级别⼩于或等于 65,将不允许 DROP COLUMN。可以列出多个列或约束。下⾯的列不能除去:
被复制列。
⽤在索引中的列。
⽤在 CHECK、FOREIGN KEY、UNIQUE 或 PRIMARY KEY 约束中的列。
有相关联的默认值(由 DEFAULT 关键字定义)的列,或绑定到默认对象的列。
绑定到规则的列。
{ CHECK | NOCHECK} CONSTRAINT
指定启⽤或禁⽤ constraint_name。如果禁⽤,将来插⼊或更新该列时将不⽤该约束条件进⾏验证。此选项只能与 FOREIGN KEY 和 CHECK 约束⼀起使⽤。
ALL
指定使⽤ NOCHECK 选项禁⽤所有约束,或者使⽤ CHECK 选项启⽤所有约束。
{ENABLE | DISABLE} TRIGGER
指定启⽤或禁⽤ trigger_name。当⼀个触发器被禁⽤时,它对表的定义依然存在;然⽽,当在表上执⾏ INSERT、UPDATE 或 DELETE 语句时,触发器中的操作将不执⾏,除⾮重新启⽤该触发器。
ALL
指定启⽤或禁⽤表中所有的触发器。
trigger_name
指定要启⽤或禁⽤的触发器名称。
column_name data_type
新列的数据类型。data_type 可以是任何 Microsoft® SQL Server™ 数据类型或⽤户定义数据类型。
DEFAULT
是指定列默认值的关键字。DEFAULT 定义可⽤于为表中现有⾏的新列提供值。DEFAULT 定义不能添加到具有 timestamp 数据类型、IDENTITY 属性、现有 DEFAULT 定义或绑定默认值的列。如果列已
有默认值,必须除去旧默认值后才能添加新默认值。为同 SQL Server 先前版本保持兼容性,向 DEFAULT 赋予约束名是可能的。
IDENTITY
指定新列是标识列。在表中添加新⾏时,SQL Server 为列提供⼀个唯⼀的增量值。标识列通常与 PRIMARY KEY 约束⼀起⽤作表的唯⼀⾏标识符。IDENTITY 属性可赋予 tinyint、smallint、int、bigint、decimal(p,0) 或者 numeric(p,0) 列。对于每个表只能创建⼀个标识列。DEFAULT 关键字和绑定默认值不能⽤于标识列。要么种⼦和增量都同时指定,要么都不指定。如果⼆者都未指定,则取默认
值 (1,1)。
Seed
是⽤于表中所装载的第⼀⾏的值。
Increment
是添加到前⼀⾏的标识值的增量值。
NOT FOR REPLICATION
指定当复制登录(如 sqlrepl)向表中插⼊数据时,不强制 IDENTITY 属性。也可对约束指定 NOT FOR REPLICATION。当复制登录向表中插⼊数据时,不检查约束条件。
CONSTRAINT
指定 PRIMARY KEY、UNIQUE、FOREIGN KEY 或 CHECK 约束的开始,或者指定 DEFAULT 定义的开始。
constrain_name
是新约束。约束的名称必须符合标识符规则,但其名称的⾸字符不能为 #。如果没有提供 constraint_name,约束使⽤系统⽣成的名称。
PRIMARY KEY
是通过唯⼀索引对给定的⼀列或多列强制实体完整性的约束。对每个表只能创建⼀个 PRIMARY KEY 约束。
UNIQUE
是通过唯⼀索引为给定的⼀列或多列提供实体完整性的约束。
CLUSTERED | NONCLUSTERED
指定为 PRIMARY KEY 或 UNIQUE 约束创建聚集或⾮聚集索引。PRIMARY KEY 约束默认为 CLUSTERED;UNIQUE 约束默认为 NONCLUSTERED。
如果表中已存在聚集约束或索引,那么在 ALTER TABLE 中就不能指定 CLUSTERED。如果表中已存在聚集约束或索引,PRIMARY KEY 约束默认为 NONCLUSTERED。
WITH FILLFACTOR = fillfactor
指定 SQL Server 存储索引数据时每个索引页的充满程度。⽤户指定的 fillfactor 取值范围从 1 到 100。如果没有指定,那么默认值为 0。创建索引时,fillfactor 值越低,不必分配新空间即可添加的新索引条⽬的可⽤空间就越多。
ON {filegroup | DEFAULT}
指定为约束创建的索引的存储位置。如果指定了 filegroup,索引将在该⽂件组内创建。如果指定了 DEFAULT,索引将在默认⽂件组内创建。如果未指定 ON,索引将在表所在的⽂件组内创建。当
为 PRIMARY KEY 或 UNIQUE 约束添加聚集索引时,如果指定了 ON,那么创建聚集索引时整个表都将移到指定的⽂件组中。
在这⾥,DEFAULT 不是⼀个关键字。DEFAULT 是默认⽂件组的标识符,必须⽤符号界定,如 ON "DEFAULT" 或 ON [DEFAULT]。
REFERENCES
是为列中数据提供引⽤完整性的约束。FOREIGN KEY 约束要求列中的每个值在被引⽤表的指定列中都存在。
ref_table
是 FOREIGN KEY 约束所引⽤的表。
ref_column
是新 FOREIGN KEY 约束所引⽤的⼀列或多列(置于括号中)。
ON DELETE {CASCADE | NO ACTION}
指定当表中被更改的⾏具有引⽤关系,并且该⾏所引⽤的⾏从⽗表中删除时,要对被更改⾏采取的操作。默认设置为 NO ACTION。
如果指定 CASCADE,则从⽗表中删除被引⽤⾏时,也将从引⽤表中删除引⽤⾏。如果指定 NO ACTION,SQL Server 将产⽣⼀个错误并回滚⽗表中的⾏删除操作。
如果表中已存在 ON DELETE 的 INSTEAD OF 触发器,那么就不能定义 ON DELETE 的CASCADE 操作。
例如,在 Northwind 数据库中,Orders 表和 Customers 表之间有引⽤关系。Orders.CustomerID 外键引⽤ Customers.CustomerID 主键。
如果对 Customers 表的某⾏执⾏ DELETE 语句,并且为 Orders.CustomerID 指定 ON DELETE CASCADE 操作,则 SQL Server 将在 Orders 表中检查是否有与被删除的⾏相关的⼀⾏或多⾏。如果存在相关⾏,那么 Orders 表中的相关⾏将随 Customers 表中的被引⽤⾏⼀同删除。
反之,如果指定 NO ACTION,若在 Orders 表中⾄少有⼀⾏引⽤ Customers 表中要删除的⾏,则 SQL Server 将产⽣⼀个错误并回滚 Customers 表中的删除操作。
ON UPDATE {CASCADE | NO ACTION}
指定当表中被更改的⾏具有引⽤关系,并且该⾏所引⽤的⾏在⽗表中更新时,要对被更改⾏采取的操作。默认设置为 NO ACTION。
如果指定 CASCADE,则在⽗表中更新被引⽤⾏时,也将在引⽤表中更新引⽤⾏。如果指定 NO ACTION,SQL Server 将产⽣⼀个错误并回滚⽗表中的⾏更新操作。
如果表中已存在 ON DELETE 的 INSTEAD OF 触发器,那么就不能定义 ON DELETE 的CASCADE 操作。
例如,在 Northwind 数据库中,Orders 表和 Customers 表之间有引⽤关系。Orders.CustomerID 外键引⽤ Customers.CustomerID 主键。
如果对 Customers 表的某⾏执⾏ UPDATE 语句,并且为 Orders.CustomerID 指定 ON UPDATE CASCADE 操作,则 SQL Server 将在 Orders 表中检查是否有与被更新⾏相关的⼀⾏或多⾏。如果存在相关⾏,那么 Orders 表中的相关⾏将随 Customers 表中的被引⽤⾏⼀同更新。
反之,如果指定了 NO ACTION,若在 Orders 表中⾄少存在⼀⾏引⽤ Customers 表中要更新的⾏,那么 SQL Server 将引发⼀个错误并回滚 Customers 表中的更新操作。
[ASC | DESC]
指定加⼊到表约束中的⼀列或多列的排序次序。默认设置为 ASC。
WITH VALUES
指定在添加到现有⾏的新列中存储 DEFAULT constant_expression 中所给定的值。只有在 ADD 列⼦句中指定了 DEFAULT 的情况下,才能使⽤ WITH VALUES。如果要添加的列允许空值且指定
了 WITH VALUES,那么将在现有⾏的新列中存储默认值。如果没有指定 WITH VALUES 且列允许空值,那么将在现有⾏的新列中存储 NULL 值。如果新列不允许空值,那么不论是否指
定 WITH VALUES,都将在现有⾏的新列中存储默认值。
column[,...n]
是新约束所⽤的⼀列或多列(置于括号中)。
constant_expression
是⽤作列的默认值的字⾯值、NULL 或者系统函数。
FOR column
指定与表级 DEFAULT 定义相关联的列。
CHECK
是通过限制可输⼊到⼀列或多列中的可能值强制域完整性的约束。
logical_expression
是⽤于 CHECK 约束的返回 TRUE 或 FALSE 的逻辑表达式。⽤于 CHECK 约束的 Logical_expression 不能引⽤其它表,但可引⽤同⼀表中同⼀⾏的其它列。
注释
若要添加新数据⾏,请使⽤ INSERT 语句。若要删除数据⾏,请使⽤ DELETE 或 TRUNCATE TABLE 语句。若要更改现有⾏中的值,请使⽤ UPDATE 语句。
ALTER TABLE 语句指定的更改将⽴即实现。如果这些更改需要修改表中的⾏,ALTER TABLE 将更新这些⾏。ALTER TABLE 将获取表上的架构修改锁,以确保在更改期间其它连接不能引⽤该表(甚⾄不能引⽤其元数据)。对表进⾏的更改将记录于⽇志中,并且可以完全恢复。影响⾮常⼤的表中所有⾏的更改,⽐如除去⼀列或者⽤默认值添加 NOT NULL 列,可能需要较长时间才能完成,并会⽣成⼤
量⽇志记录。如同影响⼤量⾏的 INSERT、UPDATE 或者 DELETE 语句⼀样,这⼀类 ALTER TABLE 语句也应⼩⼼使⽤。
如果过程⾼速缓存中存在引⽤该表的执⾏计划,ALTER TABLE 会将这些执⾏计划标记为下次执⾏时重新编译。
如果 ALTER TABLE 语句指定更改其它表所引⽤的列值,那么根据引⽤表中 ON UPDATE 或者 ON DELETE 所指定的操作,将发⽣以下两个事件之⼀。
insert语句字段顺序如果在引⽤表中没有指定值或指定了 NO ACTION(默认值),那么 ALTER TABLE 语句导致的更改⽗表中被引⽤列的操作将回滚,并且 SQL Server 将引发⼀个错误。
如果在引⽤表中指定了 CASCADE,那么由 ALTER TABLE 语句导致的对⽗表的更改将应⽤于⽗表及其相关表。
添加 sql_variant 列的 ALTER TABLE 语句会⽣成下列警告:
The total row size (xx) for table 'yy' exceeds the maximum number of bytes per row (8060). Rows that exceed the maximum number of bytes will not be added.
因为 sql_variant 的最⼤长度为 8016 个字节,所以产⽣该警告。当某 sql_variant 列所含值接近最⼤长度时,即会超过⾏长度的最⼤字节限制。
ALTER TABLE 语句对具有架构绑定视图的表执⾏时,所受限制与当前在更改具有简单索引的表时所受的限制相同。添加列是允许的。但是,不允许删除或更改参与架构绑定视图的表中的列。如
果 ALTER TABLE 语句要求更改⽤在架构绑定视图中的列,更改操作将失败,并且 SQL Server 将引发⼀条错误信息。
创建引⽤表的架构绑定视图不会影响在基表上添加或删除触发器。
当除去约束时,作为约束的⼀部分⽽创建的索引也将除去。⽽通过 CREATE INDEX 创建的索引必须使⽤ DROP INDEX 语句来除去。DBCC DBREINDEX 语句可⽤来重建约束定义的索引部分;⽽不必
使⽤ ALTER TABLE 先除去再重新添加约束。
必须删除所有基于列的索引和约束后,才能删除列。
添加约束时,所有现有数据都要进⾏约束违规验证。如果发⽣违规,ALTER TABLE 语句将失败并返回⼀个错误。
当在现有列上添加新 PRIMARY KEY 或 UNIQUE 约束时,该列中的数据必须唯⼀。如果存在重复值,ALTER TABLE 语句将失败。当添加 PRIMARY KEY 或 UNIQUE 约束时,WITH NOCHECK 选项
不起作⽤。
每个 PRIMARY KEY 和 UNIQUE 约束都将⽣成⼀个索引。UNIQUE 和 PRIMARY KEY 约束的数⽬不能导致表上⾮聚集索引的数⽬⼤于 249,聚集索引的数⽬⼤于 1。
如果要添加的列的数据类型为 uniqueidentifier,那么该列可以使⽤ NEWID() 函数作为默认值,以向表中现有⾏的新列提供唯⼀标识符值。
SQL Server 在列定义中并不强制以特定的顺序指定 DEFAULT、IDENTITY、ROWGUIDCOL 或列约束。
ALTER TABLE 的 ALTER COLUMN ⼦句并不会在列上绑定或取消绑定任何规则。必须分别使⽤ sp_bindrule 或 sp_unbindrule 来绑定或取消绑定规则。
可将规则绑定到⽤户定义数据类型。然后 CREATE TABLE 将⾃动在以该⽤户定义数据类型定义的列上绑定该规则。当⽤ ALTER COLUMN 更改列数据类型时,并不会取消绑定这些规则。原⽤户定义数
据类型上的规则仍然绑定在该列上。在 ALTER COLUMN 更改了列的数据类型之后,随后执⾏的任何从该⽤户定义数据类型上取消绑定规则的 sp_unbindrule 都不会导致从更改了数据类型的列上取消绑
定该规则。如果 ALTER COLUMN 将列的数据类型更改为绑定了规则的⽤户定义数据类型,那么绑定到新数据类型的规则不会绑定到该列。
权限
ALTER TABLE 权限默认授予表的所有者、sysadmin 固定服务器⾓⾊成员、db_owner 和 db_ddladmin 固定数据库⾓⾊成员且不可转让。
⽰例
A. 更改表以添加新列
下例添加⼀个允许空值的列,⽽且没有通过 DEFAULT 定义提供值。各⾏的新列中的值将为 NULL。
CREATE TABLE doc_exa ( column_a INT) GOALTER TABLE doc_exa ADD column_b VARCHAR(20) NULLGOEXEC sp_help doc_exaGODROP TABLE doc_exaGO
B. 更改表以除去列
下例修改表以删除⼀列。
CREATE TABLE doc_exb ( column_a INT, column_b VARCHAR(20) NULL) GOALTER TABLE doc_exb DROP COLUMN column_bGOEXEC sp_help doc_exbGODROP TABLE doc_exbGO
C. 更改表以添加具有约束的列
下例向表中添加具有 UNIQUE 约束的新列。
CREATE TABLE doc_exc ( column_a INT) GOALTER TABLE doc_exc ADD column_b VARCHAR(20) NULL    CONSTRAINT exb_unique UNIQUEGOEXEC sp_help doc_excGODROP TABLE doc_excGO
D. 更改表以添加未验证的约束
下例向表中的现有列上添加约束。该列中存在⼀个违反约束的值;因此,利⽤ WITH NOCHECK 来防⽌对现有⾏验证约束,从⽽允许该约束的添加。
CREATE TABLE doc_exd ( column_a INT) GOINSERT INTO doc_exd VALUES (-
1)GOALTER TABLE doc_exd WITH NOCHECK ADD CONSTRAINT exd_check CHECK (column_a > 1)GOEXEC sp_help doc_exdGODROP TABLE doc_exdGO
E. 更改表以添加多个带有约束的列
下例向表中添加多个带有约束的新列。第⼀个新列具有 IDENTITY 属性;表中每⼀⾏的标识列都将具有递增的新值。
CREATE TABLE doc_exe ( column_a INT CONSTRAINT column_a_un UNIQUE) GOALTER TABLE doc_exe ADD /* Add a PRIMARY KEY identity column. */ column_b INT IDENTITYCONSTRAINT column_b_p [0-9][0-9][0-9]-[0-9][0-9][0-9][0-9]" ORcolumn_d LIKE"([0-9][0-9][0-9]) [0-9][0-9][0-9]-[0-9][0-9][0-9][0-
9]"),/* Add a nonnull column with a default.  */ column_e DECIMAL(3,3)CONSTRAINT column_e_defaultDEFAULT .081GOEXEC sp_help doc_exeGODROP TABLE doc_exeGO
F. 添加具有默认值的可为空的列
下例添加可为空的、具有 DEFAULT 定义的列,并使⽤ WITH VALUES 为表中的各现有⾏提供值。如果没有使⽤ WITH VALUES,那么每⼀⾏的新列中都将具有 NULL 值。
ALTER TABLE MyTable ADD AddDate smalldatetime NULLCONSTRAINT AddDateDfltDEFAULT getdate() WITH VALUES
G. 禁⽤并重新启⽤⼀个约束
下例禁⽤⽤于限制可接受的薪⽔数据的约束。WITH NOCHECK CONSTRAINT 与 ALTER TABLE ⼀起使⽤,以禁⽤该约束并使正常情况下会引起约束违规的插⼊操作得以执⾏。
WITH CHECK CONSTRAINT 重新启⽤该约束。
CREATE TABLE cnst_example (id INT NOT NULL, name VARCHAR(10) NOT NULL, salary MONEY NOT NULL    CONSTRAINT salary_cap CHECK (salary < 100000))-
- Valid insertsINSERT INTO cnst_example VALUES (1,"Joe Brown",65000)INSERT INTO cnst_example VALUES (2,"Mary Smith",75000)-
- This insert violates the constraint.INSERT INTO cnst_example VALUES (3,"Pat Jones",105000)-
- Disable the constraint and try again.ALTER TABLE cnst_example NOCHECK CONSTRAINT salary_capINSERT INTO cnst_example VALUES (3,"Pat Jones",105000)-
- Reenable the constraint and try another insert, will fail.ALTER TABLE cnst_example CHECK CONSTRAINT salary_capINSERT INTO cnst_example VALUES (4,"Eric James",110000)
H. 禁⽤并重新启⽤触发器
下例使⽤ ALTER TABLE 的 DISABLE TRIGGER 选项来禁⽤触发器,以使正常情况下会违反触发器条件的插⼊操作得以执⾏。然后下例使⽤ ENABLE TRIGGER 重新启⽤触发器。
CREATE TABLE trig_example (id INT, name VARCHAR(10),salary MONEY)go-
- Create the trigger.CREATE TRIGGER trig1 ON trig_example FOR INSERTas IF (SELECT COUNT(*) FROM INSERTEDWHERE salary > 100000) > 0BEGINprint "TRIG1 Error: you attempted to insert a salary > $ - Attempt an insert that violates the trigger.INSERT INTO trig_example VALUES (1,"Pat Smith",100001)GO-- Disable the trigger.ALTER TABLE trig_example DISABLE TRIGGER trig1GO-
- Attempt an insert that would normally violate the triggerINSERT INTO trig_example VALUES (2,"Chuck Jones",100001)GO-- Re-
enable the trigger.ALTER TABLE trig_example ENABLE TRIGGER trig1GO-- Attempt an insert that v
iolates the trigger.INSERT INTO trig_example VALUES (3,"Mary Booth",100001)GO

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。