华 中 科 技 大 学
《数据库技术与应用》实验报告
专业班级: 学生姓名: 学号: 实验地点: 指导教师: 实验日期时间:
一、实验项目名称:索引和视图 二、实验学时: 三、实验目的: 1. 2. 3. 4. 5. 6. 7. 学会使用SQL Server管理平台和Transact-SQL语句CREATE INDEX创建索引。 学会使用SQL Server管理平台查看索引。 学会使用SQL Server管理平台和Transact-SQL语句DROP INDEX删除索引。 掌握使用SQL Server管理平台和Transact-SQL语句CREATE-VIEW创建视图的用法。 了解对索引和视图更名的系统存储过程sp_rename的用法。 掌握使用Transact-SQL语句ALTER VIEW修改视图的方法。 了解删除视图的Transact-SQL语句DROP VIEW的用法。 五、实验内容、步骤、代码和结果: 0. 创建studentsdb数据库及其相应表,并录入数据。 在SQL Server管理平台上,点击“新建查询”打开查询编辑器窗口,复制粘贴附件“创建数据库代码”中的代码到查询编辑器窗口,运行即可生成相关数据库和表,并有相应的数据。 1. 分别使用SQL Server管理平台和Transact-SQL语句为studentsdb数据库的student_info表和curriculum表创建主键索引。 alter table student_info alter column 学号 char(4) not null; alter table student_info add primary key(学号) alter table curriculum alter column 课程编号 char(4) not null; alter table curriculum add primary key(课程编号) 2. 使用SQL Server管理平台按curriculum表的课程编号列创建唯一性索引。 create unique index 课程编号_idx on curriculum(课程编号) 四、实验工具或环境 3.分别使用SQL Server管理平台和Transact-SQL语句为studentsdb数据库的grade表的“分数”字段创建一个非聚集索引,命名为grade_index。 create index grade_index on grade(分数) 1 / 6
4.为studentsdb数据库的grade表的“学号”和“课程编号”字段创建一个复合唯一索引,命名为grade_id_c_ind。 create index grade_id_c_ind on grade (学号,课程编号) 5.分别使用SQL Server管理平台和系统存储过程sp_helpindex查看grade表和student_info表上的索引信息。 EXEC Sp_helpindex grade 7.使用系统存储过程sp_rename将索引grade_index更名为grade_ind。 use studentsdb go exec sp_rename 'grade.grade_index','grade_ind' 8.分别使用SQL Server管理平台和Transact-SQL语句DROP INDEX删除索引grade_ind。再次使用系统存储过程sp_helpindex查看grade表上的索引信息。 EXEC Sp_helpindex student_info use studentsdb go drop index grade_ind on grade 6.使用SQL Server管理平台对grade表创建一个聚集索引和唯一索引。 2 / 6
9.在studentsdb数据库中,以student_info表为基础,使用SQL Server管理平台建立名为v_stu_i的视图,使视图显示学生姓名、性别、家庭住址。 11.基于student_info表、curriculum表和grade表,建立一个名为v_stu_g的视图,视图中具有所有学生的学号、姓名、课程名称、分数。使用视图v_stu_g查询学号为0001的学生的所有课程和成绩,如图5-1所示。 学号 0001 0001 0001 0001 0001 姓名 刘卫平 刘卫平 刘卫平 刘卫平 刘卫平 课程名称 大学计算机基础 C语言程序设计 SQL Server数据库 英语 高等数学 分数 80 90 87 86 78 10.在studentsdb数据库中,使用Transact-SQL语句 CREATE VIEW 建立一个名为v_stu_c的视图,显示学生的学号、姓名、所学课程的课程编号,并利用视图查询学号为0003的学生情况。 create view v_stu_c as select a.学号,姓名 ,b.课程编号 from student_info a inner join grade b on a.学号=b.学号 ▶ 图5-1 学号为0001的学生的视图信息 create view v_stu_g as select student_info.学号,姓名,课程名称,分数 from student_info, curriculum ,grade where student_info.学号=grade.学号 and curriculum.课程编号 =grade.课程编号 select * from v_stu_c where 学号='0003' 12.分别使用SQL Server管理平台和Transact-SQL语句修改视图v_stu_c,使之显示学号、姓名、每个学生所学课程数目。 3 / 6
14.使用系统存储过程sp_rename将视图v_stu_i更名为v_stu_info。 sp_rename v_stu_i,v_stu_info 15.利用视图v_stu_i为student_info表添加一行数据:学号为0015、姓名为陈婷、性别为女。 insert into v_stu_i values ('0015','陈婷','女') alter view v_stu_c as select student_info .学号 ,姓名,count(课程编号 )as 课程数目 from grade inner join studentsdb.dbo.student_info on grade.学号=student_info.学号 group by student_info .学号,姓名 16.利用视图v_stu_i删除学号为0015的学生记录。 delete from v_stu_i where 学号='0015' 13.使用Transact-SQL语句ALTER VIEW 修改视图v_stu_i,使其具有列名学号、姓名、性别。 alter view v_stu_i as select 学号 ,姓名,性别 from studentsdb.dbo.student_info 17.利用视图v_stu_g修改姓名为刘卫平的学生的高等数学的分数为84。 update v_stu_g set 分数='84' where 姓名 ='刘卫平'and 课程名称 ='高等数学' 18.使用Transact-SQL语句DROP VIEW 删除视图v_stu_c和v_stu_g。 drop view v_stu_c,v_stu_g 4 / 6
5 / 6
六、实验思考 1.比较通过视图和基表操作表中数据的异同。 在数据修改,查询等方面视图与表基本相同。但视图是虚拟表,并不储存数据 2.可更新视图必须满足哪些条件。(1)任何修改(包括 UPDATE、INSERT 和 DELETE 语句)都只能引用一个基本表 的列。 (2)视图中被修改的列必须直接引用表列中的基础数据。不能通过任何其他方式对 这些列进行派生,如通过聚合函数、计算(如表达式计算) 、集合运算等。 (3)被修改的列不受 GROUP BY、HAVING、DISTINCT 或 TOP 子句的影响 3.什么是索引?SQL Server2008中有聚集索引和非聚集索引,简单叙述它们的区别。聚集索引和非聚集索引,简单叙述它们的区别? 索引是对数据库表中一列或多列的值进行排序的一种结构。 一个表中只能有一个聚集索引,但是可以有249个非聚集索引。聚集索引查找数据比非聚集索引要快很多,但是会比非聚集索引所占空间要大很多 4.能否在视图上创建索引?不能 七、总结及心得体会: 视图与表类似,在选择与修改上基本相同 八、对本实验过程及方法、手段的改进建议: 教师 评语 及成绩 指年 月 日
导教师签名 6 / 6