网站大量收购独家精品文档,联系QQ:2885784924

数据库完整性与安全性实验报告数据库完整性与安全性实验报告.pdf

数据库完整性与安全性实验报告数据库完整性与安全性实验报告.pdf

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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,实现功能:当向学生

文档评论(0)

tazhiq2 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档