- 1、本文档共9页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据库完整性与安全性实验报告数据库完整性与安全性实验报告
北京邮电大学
实验报告
课程名称 数据库系统原理
实验内容 实验五
实验名:数据库完整性与安全性实验
2012 年 05 月 10 日
实验五 数据库完整性与安全性实验
实验目的
1、通过对完整性规则的定义实现,熟悉了解sql sever 中完整性保证的规则和实现方法,
加深对数据完整性的理解。
2、通过对安全性相关内容的定义,熟悉了解sql sever 中安全性的内容和实现方法,加深
对数据库安全性的理解。
实验平台及环境
本机为windows 7 操作系统平台, SQL Server 2008 数据库。
实验内容
完整性实验
(1) 分别定义学生数据库中各基表的主键、外键,实现实体完整性约束和参照完整性约
束;
(2) 分别向学生表、课程表插入具有相同学号和相同课程编号的学生数据和课程数据,
验证其实体完整性约束;
(3) 向学生选课表中插入一条数据,课程编号是课程表中没有的,验证参照完整性约束;
(4) 删除学生表中的所有数据,验证参照完整性约束;
(5) 定义存储过程,完成查询某个学生的选课情况,并执行。
(6) 定义触发器,当向学生表插入新的一条记录时,将所有学生出生日期加 1;并对其
进行测试。
(7) 用sql 完成以上操作。
安全性实验
(1) 定义一新的登陆帐号、数据库用户,并授予其访问学生数据库的读权限;
(2) 分别用sa 用户和新定义的用户访问学生数据库,并对其中的学生表数据进行修改;
(3) 创建数据库角色,并授予访问学生数据库的读、写权限;
(4) 将角色赋予(1)中定义的用户,建立用户和角色联系;
(5) 再次用此用户访问学生数据库,并对其中的学生表数据进行修改。
(6) 用SQL 语句分别完成以上内容。
实验步骤和结果分析
一、完整性实验
1、定义学生数据库中各基表的主键、外键,实现实体完整性约束和参照完整性约束
alter table 课程 add primary key (课程编号)
alter table 选修 add primary key (课程编号,学号)
alter table 学生 add primary key (学号)
alter table 选修 add foreign key (课程编号) references 课程(课程编号)
alter table 选修 add foreign key (学号) references 学生(学号)
结果如下图:
2、向学生表、课程表插入具有相同学号和相同课程编号的学生数据和课程数据,验证其实
体完整性约束
例如:向课程表中插入计算机网络课程,
insert into 课程 values (C01,计算机网络,51,3,秋)
但由于课程编号与原表数据有重,故而执行报错:
同理:向学生表中插入张明的信息,
insert into 学生 values (30201,张明 ,女 ,1980-1-2 00:00,计算机
,3146)
但由于其学号与原表数据有重,故而执行报错:
即验证了其实体完整性约束
3、向学生选课表中插入一条数据,课程编号是课程表中没有的,验证参照完整性约束
例如:向选课表中插入学号为30201 的同学的某项选课信息,
insert into 选修 values (30201,CO6,51)
但由于其课程编号是课程表中没有的,执行报错
即验证了参照完整性约束
4、删除学生表中的所有数据,验证参照完整性约束
使用delete from 学生
但由于参照完整性的约束,执行报错
即验证了参照完整性约束
5、定义存储过程,完成查询某个学生的选课情况,并执行
例如:定义了存储过程wlxx,用来查询吴磊学生的选课情况,
create procedure wlxx as
select 学生.学号,姓名,课程名称,学生成绩
from 学生,课程,选修
where 学生.学号=30201 and 学生.学号=选修.学号 and 选修.课程编号=课程.课
程编号
go
创建成功后在对象资源管理器中可以找到它
执行即可得到吴磊学生的选课情况,exec wlxx
6、定义触发器,当向学生表插入新的一条记录时,将所有学生出生日期加 1;并对其进行
测试
这里我定义了触发器 dadd,实现功能:当向学生
您可能关注的文档
- 数学建模获奖样例数学建模获奖样例.doc
- 数学思维训练备课数学思维训练备课.doc
- 数学教育之取势明道优术_章建跃_陈向兰数学教育之取势明道优术_章建跃_陈向兰.pdf
- 数学文科金版教程限时规范特训手册数学文科金版教程限时规范特训手册.doc
- 数学物理方程1 电子科技大学 李明奇数学物理方程1 电子科技大学 李明奇.pdf
- 数学建模协会建会答辩演讲稿数学建模协会建会答辩演讲稿.ppt
- 数学教育概论之小学数学说课稿范例数学教育概论之小学数学说课稿范例.ppt
- 数学150+理综297分状元学姐学习经验贴数学150+理综297分状元学姐学习经验贴.pdf
- 数学期望的定义数学期望的定义.pdf
- 数学必修5课本答案数学必修5课本答案.ppt
文档评论(0)