- 1、本文档共13页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验五 实体参照完整性以及索引的建立和使用
实验五指导
5.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=789where Sname=小二
select * from Stu_Union
use School
insert Stu_Union values(789,小三,M,23)
演示违反实体完整性的更新操作
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生成主键和外键的情况。
建立并插入数据
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
相关演示
use School
alter table Scholarship add
consraint PK_Scholarship primary key(M_id)
无法建立
use School
alter table Scholarship add
constraint FK_Scholarship foreign key(Stu_id) references
Students(Sno)
5.2参照完整性
为演示参照完整性,建立表Course,令cno为其主键,并在Stu_Union中插入数据。为下面的实验步骤做预先准备。
create table Course(
Cno CHAR(4) NOT NULL UNIQUE,
Cname VARCHAR(50) NOT NULL,
Cpoints INT,
CONSTRAINT PK PRIMARY KEY(Cno));
insert Course values(C001,C++,2);
insert Course values(C002,Java,3);
建立表sc,另sno和cno分别为参照Stu_Union表以及Course表的外键,设定为级连删除,并令(sno, cno)为其主键。在不违反参照完整性的前提下,插入数据。
use School
crea
您可能关注的文档
- 实习过程中的沟通技巧Microsoft Office PowerPoint 演示文稿.ppt
- 实变函数论3.1 外测度.ppt
- 实战演练 Unit01-Unit10.pdf.doc
- 实数教材分析.ppt
- 实例1——MODFLOW操作说明new.doc
- 实施药物GCP指导模板---Ⅰ期临床试验(临床研究、分析测试).doc
- 实体Sales培训ppt.ppt
- 实施可持续发展战略(最新)PPT.ppt
- 实现品管工具的九大步骤.ppt
- 实用商务英语函电课件-Unit 3.ppt
- 安全生产考核奖惩制度3篇.doc
- 颅脑损伤病人的护理查房【优质公开课】精品PPT课件模板.pptx
- 二零二二年度德州继续教育公需科目《公共事务管理与服务能力》试题及答案.pdf
- 二零二二年度党风廉政建设知识竞赛题库(含答案).pdf
- 二零二二年度度枣庄市专业技术人员继续教育公需科目培训班互动题.pdf
- 二零二二年度儿童保健学试题库(含答案).pdf
- 二零二二年度第十九届中国东南地区数学奥林匹克竞赛高一试题(含答案).pdf
- 二零二二年度动物卫生监督题库(含答案).pdf
- 黑龙江省大庆市重点中学2023-2025学年高一下学期2月开学考试英语试题(含解析).docx
- 二零二二年度法检书记员招考《公基》测试题库(含答案).pdf
文档评论(0)