实验五 实体参照完整性以及索引的建立和使用

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验五指导

5.1 实体完整性

1)在数据库School中建立表Stu_Union,进行主键约束,在没有违反实体完整性的前提下插入并更新一条记录

use School

create table Stu_Union(

Sno char(8)not null unique,

Sname char(8),

Ssex char(1),

Sage int,

constraint PK_Stu_Union primary key(Sno)

)

insert Stu_Union values('456','小二','M','22')

update Stu_Union set Sno=''WHERE Sage='22'

update Stu_Union set Sno='789'where Sname='小二'

select*from Stu_Union

2)演示违反实体完整性的插入操作

use School

insert Stu_Union values('789','小三','M','23')

3)演示违反实体完整性的更新操作

use School

update Stu_Union set Sno=NULL where Sno='789'

4)演示事务的处理,包括事务的建立,处理以及出错时的事务回滚,演示事务处理和批处理的区别。

提示:SQL2005相关语句为

BEGIN TRAN

ROLLBACK TRAN

COMMIT TRAN

可以这样演示:新建一个包含两条语句的事务,使第一条成功而第二条失败,然后查看整个事务是否回滚。

重要提示:SQL默认只回滚出错的语句,要回滚整个事务,需要预先执行以下语句:SET XACT_ABORT ON

事务的建立

use School

set xact_abort on

begin transaction t1

insert into Stu_Union values('001','张三','M','22')

insert into Stu_Union values('002','李四','F','24')

insert into Stu_Union values('003','李四','F','24')

select*from Stu_Union

commit transaction t1

处理以及出错时的回滚

use School

set xact_abort on

begin transaction t2

insert into Stu_Union values('004','王五','M','23')

select*from Stu_Union

insert into Stu_Union values('789','钱六','F','21')

commit transaction t2

use School

select*from Stu_Union

5)通过建立Scholarship表,插入一些数据。演示当与现有的数据环境不等时,无法建立实体完整性以及参照完整性。

提示:即演示不能为表Scholarship生成主键和外键的情况。

1)建立并插入数据

use School

create table Scholarship(

M_id varchar(10),

Stu_id char(8),

R_Money int,

)

insert into Scholarship values ('M001','004','2000')

insert into Scholarship values ('M002','005','3000')

select*from Scholarship

2)相关演示

use School

alter table Scholarship add

consraint PK_Scholarship primary key(M_id)

3)无法建立

use School

alter table Scholarship add

constraint FK_Scholarship foreign key(Stu_id)references

Students(Sno)

5.2参照完整性

1)为演示参照完整性,建立表Course,令cno为其主键,并在Stu_Union中插入数据。为下面的实验步骤做预先准备。

create table Course(

Cno CHAR(4)NOT NULL UNIQUE,

Cname V ARCHAR(50)NOT NULL,

Cpoints INT,

CONSTRAINT PK PRIMARY KEY(Cno));

insert Course values('C001','C++',2);

insert Course values('C002','Java',3);

2)建立表sc,另sno和cno分别为参照Stu_Union表以及Course表的外键,设定为级连删除,并令(sno, cno)为其主键。在不违反参照完整性的前提下,插入数据。

use School

create table SC(

Sno CHAR(8),

Cno CHAR(4),

Scredit INT,

constraint PK_SC primary key(Sno,Cno),

constraint FK_SC_Sno foreign key(Sno)references Stu_Union(Sno)on delete cascade, constraint FK_SC_Cno foreign key(Cno)references Course(Cno)on delete cascade

);

INSERT INTO SC V ALUES('002','C001',2);

INSERT INTO SC V ALUES ('002','C002',2);

INSERT INTO SC V ALUES ('001','C001',2);

INSERT INTO SC V ALUES ('001','C002',2);

SELECT*FROM SC;

3)演示违反参照完整性的插入数据

use School

insert into SC values('099','C099',2)

相关文档
最新文档