华中科技大学
《数据库技术与应用》实验报告
专业班级:学生姓名:学号:
实验地点:指导教师:
实验日期时间:
一、实验项目名称:索引和视图
二、实验学时:
三、实验目的:
1.学会使用SQL Server管理平台和Transact-SQL语句CREATE INDEX创建索引。
2.学会使用SQL Server管理平台查看索引。
3.学会使用SQL Server管理平台和Transact-SQL语句DROP INDEX删除索引。
4.掌握使用SQL Server管理平台和Transact-SQL语句CREATE-VIEW创建视图的用法。
5.了解对索引和视图更名的系统存储过程sp_rename的用法。
6.掌握使用Transact-SQL语句ALTER VIEW修改视图的方法。
7.了解删除视图的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(分数)
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
EXEC Sp_helpindex student_info
6.使用SQL Server管理平台对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表上的索引信息。
use studentsdb
go
drop index grade_ind on grade
9.在studentsdb数据库中,以student_info表为基础,使用SQL Server管理平台建立名为v_stu_i的视图,使视图显示学生姓名、性别、家庭住址。
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.学号
select*from v_stu_c where学号='0003'
11.基于student_info表、curriculum表和grade表,建立一个名为v_stu_g的视图,视图中具有所有学生的学号、姓名、课程名称、分数。
使用视图v_stu_g查询学号为0001的学生的所有课程和成绩,如图5-1所示。
学号姓名课程名称分数
0001 刘卫平大学计算机基础80
0001 刘卫平C语言程序设计90
0001 刘卫平SQL Server数据库87
▶0001 刘卫平英语86
0001 刘卫平高等数学78
图5-1 学号为0001的学生的视图信息
create view v_stu_g
as
select student_info.学号,姓名,课程名称,分数from student_info,curriculum,grade where student_info.学号=grade.学号and curriculum.课程编号=grade.
课程编号
12.分别使用SQL Server管理平台和Transact-SQL语句修改视图v_stu_c,使之显示学号、姓名、每个学生所学课程数目。
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.学号,姓名
13.使用Transact-SQL语句ALTER VIEW 修改视图v_stu_i,使其具有列名学号、姓名、性别。
alter view v_stu_i as select学号,姓名,性别
from studentsdb.dbo.student_info
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','陈婷','女')
16.利用视图v_stu_i删除学号为0015的学生记录。
delete from v_stu_i where学号='0015'
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。