- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据库实验三 数据更新等
实验五实验报告
一、实验目的
1.掌握实体完整性约束、参照完整性约束;
2. 灵活应用完整性约束‘
3. 了解触发器在的应用
4. 理解索引的功能和运用并掌握索引的建立方法;
二、实验内容
5.1 实体完整性
1)在数据库School中建立表Stu_Union,进行主键约束,在没有违反实体完整性的前提下插入并更新一条记录
建立表Stu_Union,进行主键约束
在没有违反实体完整性的前提下插入一条记录
在没有违反实体完整性的前提下更新一条记录
2)演示违反实体完整性的插入操作
3)演示违反实体完整性的更新操作
4)演示事务的处理,包括事务的建立,处理以及出错时的事务回滚,演示事务处理和批处理的区别。
提示:SQL2005相关语句为
BEGIN TRAN
ROLLBACK TRAN
COMMIT TRAN
可以这样演示:新建一个包含两条语句的事务,使第一条成功而第二条失败,然后查看整个事务是否回滚。
重要提示:SQL默认只回滚出错的语句,要回滚整个事务,需要预先执行以下语句:
SET XACT_ABORT ON
先执行如下SQL语句(可执行成功)
再执行如下语句,此时为执行第一句insert语句成功,第二句insert语句失败
查询事物是否回滚
由上可知,表为b步骤即事物出错前的状态,所以整个事物回滚。
5)通过建立Scholarship表,插入一些数据。演示当与现有的数据环境不等时,无法建立实体完整性以及参照完整性。
提示:即演示不能为表Scholarship生成主键和外键的情况。
a.
b. 不能为表Scholarship生成主键
不能为表Scholarship生成外键
5.2参照完整性
1)为演示参照完整性,建立表Course,令cno为其主键,并在Stu_Union中插入数据。为下面的实验步骤做预先准备。
在Stu_Union中插入数据
建立表Course,令cno为其主键
2)建立表sc,另sno和cno分别为参照Stu_Union表以及Course表的外键,设定为级连删除,并令(sno, cno)为其主键。在不违反参照完整性的前提下,插入数据。
3)演示违反参照完整性的插入数据
4)在Stu_Union中删除数据,演示级连删除。
5)Course中删除数据,演示级连删除 。
6)为了演示多重级连删除,建立Stu_Card表,令stu_id为参照Stu_Union表的外键,令card_id为其主键,并插入数据。
7)为了演示多重级连删除,建立ICBC_Card表,令stu_card_id为参照Stu_Card表的外键,令bank_id为其主键,并插入数据。
8)通过删除stu_union表中的一条记录,演示三个表的多重级连删除。
未删除时
删除stu_union记录sno=10004
结果:
9)演示事务中进行多重级连删除失败的处理。修改ICBC_Card表的外键属性,使其变为On delete No action, 演示事务中通过删除stu_union表中的一条记录,多重级连删除失败,整个事务回滚到事务的初始状态。
修改外键属性:
事务中多重级连删除失败
查询事务回滚
5.3索引的建立和作用
实验目的
学会在SQL SERVER中建立索引
通过本实验体会覆盖索引的作用,在以后的实践中,能适时地使用覆盖索引来提高数据库的性能。
通过实验体会聚簇索引的优缺点,学会根据具体情况创建聚簇索引
实验内容
STUDENTS(sid,sname,email,grade)在sname上建立聚簇索引,grade上建立非聚簇索引,并分析所遇到的问题
分析问题:1.Cluster后要ed
2.要删除本来存在的聚集索引,在删除前应先移除主键
数据库SCHOOL的选课表CHOICES有如下结构:
CHOICES(no,sid,tid,cid,score)
假设选课表集中用于查询分析,经常执行统计某课程修读的学生人数查询访问
要求:
首先执行没有索引的实验(设数据库CHOICES表在cid列上没有索引)
然后做有索引的实验
对比试验结果,并进行分析
对比查询同一条指令占用时间可得,建立索引后查询快得多。
以数据库SCHOOL中CHOICES表为例,设建表时考虑到以后经常有一个用sid查询此学生所有选课信息的查询,考虑到一般学生不止选一门课,且要询问这些记录的所有信息,故在sid上建立索引,使相同sid的记录存在一起,取数据页面时能一起取出来,减少数据页面的存取次数
要求:
首先执行没有任何索引的情况
在sid上建有非聚簇索引的情况
在sid上建有聚簇索引的情况
对比
文档评论(0)