4.3 使用Transact-SQL创建和管理表
4.3.1 使用Transact-SQL创建表
创建表的Transact-SQL语句是CREATE TABLE语句,其基本语法如下:
CREATE TABLE语句的参数及说明如表4.5所示。
表4.5 CREATE TABLE语句的参数及说明
【例4.8】成绩管理数据库AMDB中要继续增加新表,现在要增加的表是教师(teacher)表课程(course)表和,两个表的具体结构如表4.6和表4.7所示。
表4.6 教师(teacher)表
表4.7 课程(course)表
具体操作步骤如下:
(1)创建教师(teacher)表的SQL语句如下:
(2)创建课程(course)表的SQL语句如下:
4.3.2 使用Transact-SQL修改表字段
修改表字段的Transact-SQL语句是ALTER TABLE语句,其基本语法如下:
ALTER TABLE语句的参数及说明如表4.8所示。
表4.8 ALTER TABLE语句的参数及说明
【例4.9】现在要对成绩管理数据库AMDB中的表进行字段修改,修改的内容包括:
● 将教师(teacher)表职称proTitle字段的数据类型修改为varchar(5)。
● 增加教师(teacher)表政治面貌polity字段,数据类型char(2),不允许为空。
● 此外前面创建的学生(student)表中的年龄age字段可以由出生日期birthday字段计算获得,因此将学生(student)表中的年龄age字段删除。
具体操作步骤如下:
(1)修改教职称proTitle字段的SQL语句如下:
(2)增加政治面貌polity字段的SQL语句如下:
ALTER TABLE[dbo].[teacher] --修改表teacher
ADD polity char(2)not null --增加polity字段
(3)删除照片imagephoto字段的SQL语句如下:
ALTER TABLE[dbo].[student] --修改表student
DROP COLUMN age --删除age字段
4.3.3 使用Transact-SQL设置表约束
创建约束的Transact-SQL语句有两种:一种是CREATE TABLE语句,在创建表的时候就指定约束;另一种是ALTER TABLE语句在已建立表上进行约束的设置,其基本语法如下:
【例4.10】成绩管理数据库AMDB中要继续增加新表,现在要增加的表是成绩(grade)表,具体结构如表4.9所示,然后继续给grade表中的score字段追加检查约束,设置条件为成绩取值为0~100分之间。
表4.9 成绩(grade)表
具体操作步骤如下:
(1)创建成绩(grade)表的SQL语句如下:
(2)给score字段的追加检查约束的SQL语句如下:
4.3.4 使用Transact-SQL重命名表
重命名表的Transact-SQL是采用系统存储过程sp_rename,它的功能是在当前数据库中更改用户创建对象的名称。此对象可以是表、索引、列、别名数据类型或Microsoft.NET Framework公共语言运行时(CLR)用户定义类型。其基本语法如下:
sp_rename[@objname=]’object_name’,[@newname=]’new_name’
[,[@objtype=]’object_type’]
系统存储过程sp_rename的参数及说明如表4.10所示。
表4.10 系统存储过程sp_rename的参数及说明
【例4.11】将成绩管理数据库AMDB中grade表更名为score。
SQL语句如下:
4.3.5 使用Transact-SQL删除表
删除表的Transact-SQL语句是DROP DATABASE语句,其基本语法如下:
DROP TABLE[database_name.[schema_name].
|schema_name.]table_name[,...n][;]
【例4.12】使用DROP TABLE语句删除ReportServer数据库上的DataSets和ConfigurationInfo表。
【例4.12】
SQL语句如下:
注意:
不能使用DROP TABLE删除被FOREIGN KEY约束引用的表。必须先删除引用FOREIGN KEY约束或引用表。如果要在同一个DROP TABLE语句中删除引用表以及包含主键的表,则必须先列出引用表。
如果要删除通过外键和主键约束的外键表和主键表,则必须首先删除外键表。如果要删除外键约束中引用的主键表而不删除外键表,则必须删除外键表的外键约束。
删除表时,表的规则或默认值将被解除绑定,与该表关联的任何约束或触发器将被自动删除。