我的编程空间,编程开发者的网络收藏夹
学习永远不晚

SQL学习之使用命令方式创建、删除与修改关系表

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

SQL学习之使用命令方式创建、删除与修改关系表

首先,先介绍用命令方式创建、删除和修改关系表,

(1)、创建表

基本格式:create table 表名

      (

      列名 数据类型 列级完整性约束,列名 数据类型 列级完整性约束(如果有多个列,注意要用       英文式的逗号隔开)

      ,表级完整性约束(表级完整性约束和列级完整性约束之间也要用逗号分隔开)

      )

列级完整性约束有:
not null限制列取值为空
default指定列的默认值
unique定义列取值不能重复
check定义列的取值范围(check是定义的多列之间的取值约束,只能在表级完整性约束)处定义
primary key定义主码约束
foreign key定义外码约束
表级完整性约束:
unique定义列取值不能重复
check定义列的取值范围(check是定义的多列之间的取值约束,只能在表级完整性约束)处定义
primary key定义主码约束
foreign key定义外码约束


知道呢有哪些约束,那么,怎么定义完整性约束呢?他们的格式是什么呢?

主码约束:primary key (列名,列名,列名......)


外码约束:foreign key (列名) references 外表名 (外表列名)


unique约束:列名 数据类型 unique (列名,列名......)


default约束:列名 default 默认值


check约束:check 逻辑表达式(逻辑表达式中不能包含来自多个表的列)


(2)、修改表:


基本格式: alter table 表名

       alter column 列名 新的数据类型     (修改列的定义)

       add 列名 数据类型 约束         (增加新的列)

       drop column 列名              (删除列)

       add 约束定义                 (添加约束)

       drop 约束名                  (删除约束)


注意:不同的DBMS的alter table语句格式都不同,在这里以SQL2014为例     


(3)、删除表:


基本格式: drop table 表名


注意:如果被删除的表中有其他表对他的外码引用约束,则必须先删除外码所在的表,然后再删除被引     用码所在的表


实例说明:(1)创建3张表,学生表(student)、课程表(course)和学生选课表(sc)

学生表(student)

列名含义数据类型约束
Sno学号char(11)主码
Sname姓名nchar(4)非空
Snumber×××号char(18)取值不重
Ssex性别nchar(1)默认值为'男'
Sage年龄tinyint取值范围为15—45
Sdept所在系nvarchar(20)


创建student表代码:

use student

create table student

(

Sno char(11) primary key,

Sname nchar(4) not null,

Snumber char(18) unique,

Ssex nchar(1) default '男',

Sage tinyint check(sage >= 15  and sage <= 45),

Sdept nvarchar(20)

)


课程表(course)

列名含义数据类型约束
Cno课程号char(6)主码
Cname课程名nvarchar(20)非空
Credit学分numeric(3,1)大于0
Semester学期tinyint


创建course表代码:

use student

create table course

(

Cno char(6) primary key,

Cname nvarchar(20) not null,

Credit numeric(3,1) check(Credit > 0),

Semeter tinyint

)


选课表(sc)

列名含义数据类型约束
Sno学号char(11)主码,引用student的外码
Cno课程号char(6)主码,引用course的外码
Grade成绩tinyint


创建sc表代码:

use student

create table sc

(

Sno char(11) not null,

Cno char(6) not null,

Grade tinyint,

primary key (sno,cno),

foreign key (sno) references student(sno),

foreign key (cno) references course(cno)

)


(2)为sc表添加‘修课类别’(type)列,允许为空,代码如下:

alter table sc

add type nchar(1) null


(3)为sc表添加‘修课类别’(type)列修改他的数据类型为nchar(2),代码如下:

alter table sc

alter column type nchar(2)


(4)为sc表添加‘修课类别’(type)列添加取值范围为{必修,重修,选修}的约束,代码如下:

alter table sc

add check(type in ('必修','重修','选修'))


(5)删除type列,代码如下:

alter table sc

drop column type

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

SQL学习之使用命令方式创建、删除与修改关系表

下载Word文档到电脑,方便收藏和打印~

下载Word文档

编程热搜

目录