您好,欢迎访问三七文档
当前位置:首页 > IT计算机/网络 > 数据库 > 数据库实验五 索引和视图
1/6华中科技大学《数据库技术与应用》实验报告专业班级:学生姓名:学号:实验地点:指导教师:实验日期时间:一、实验项目名称:索引和视图二、实验学时:三、实验目的:1.学会使用SQLServer管理平台和Transact-SQL语句CREATEINDEX创建索引。2.学会使用SQLServer管理平台查看索引。3.学会使用SQLServer管理平台和Transact-SQL语句DROPINDEX删除索引。4.掌握使用SQLServer管理平台和Transact-SQL语句CREATE-VIEW创建视图的用法。5.了解对索引和视图更名的系统存储过程sp_rename的用法。6.掌握使用Transact-SQL语句ALTERVIEW修改视图的方法。7.了解删除视图的Transact-SQL语句DROPVIEW的用法。四、实验工具或环境五、实验内容、步骤、代码和结果:0.创建studentsdb数据库及其相应表,并录入数据。在SQLServer管理平台上,点击“新建查询”打开查询编辑器窗口,复制粘贴附件“创建数据库代码”中的代码到查询编辑器窗口,运行即可生成相关数据库和表,并有相应的数据。1.分别使用SQLServer管理平台和Transact-SQL语句为studentsdb数据库的student_info表和curriculum表创建主键索引。altertablestudent_infoaltercolumn学号char(4)notnull;altertablestudent_infoaddprimarykey(学号)altertablecurriculumaltercolumn课程编号char(4)notnull;altertablecurriculumaddprimarykey(课程编号)2.使用SQLServer管理平台按curriculum表的课程编号列创建唯一性索引。createuniqueindex课程编号_idxoncurriculum(课程编号)3.分别使用SQLServer管理平台和Transact-SQL语句为studentsdb数据库的grade表的“分数”字段创建一个非聚集索引,命名为grade_index。createindexgrade_indexongrade(分数)2/64.为studentsdb数据库的grade表的“学号”和“课程编号”字段创建一个复合唯一索引,命名为grade_id_c_ind。createindexgrade_id_c_indongrade(学号,课程编号)5.分别使用SQLServer管理平台和系统存储过程sp_helpindex查看grade表和student_info表上的索引信息。EXECSp_helpindexgradeEXECSp_helpindexstudent_info6.使用SQLServer管理平台对grade表创建一个聚集索引和唯一索引。7.使用系统存储过程sp_rename将索引grade_index更名为grade_ind。usestudentsdbgoexecsp_rename'grade.grade_index','grade_ind'8.分别使用SQLServer管理平台和Transact-SQL语句DROPINDEX删除索引grade_ind。再次使用系统存储过程sp_helpindex查看grade表上的索引信息。usestudentsdbgodropindexgrade_indongrade3/69.在studentsdb数据库中,以student_info表为基础,使用SQLServer管理平台建立名为v_stu_i的视图,使视图显示学生姓名、性别、家庭住址。10.在studentsdb数据库中,使用Transact-SQL语句CREATEVIEW建立一个名为v_stu_c的视图,显示学生的学号、姓名、所学课程的课程编号,并利用视图查询学号为0003的学生情况。createviewv_stu_casselecta.学号,姓名,b.课程编号fromstudent_infoainnerjoingradebona.学号=b.学号select*fromv_stu_cwhere学号='0003'11.基于student_info表、curriculum表和grade表,建立一个名为v_stu_g的视图,视图中具有所有学生的学号、姓名、课程名称、分数。使用视图v_stu_g查询学号为0001的学生的所有课程和成绩,如图5-1所示。学号姓名课程名称分数0001刘卫平大学计算机基础800001刘卫平C语言程序设计900001刘卫平SQLServer数据库87▶0001刘卫平英语860001刘卫平高等数学78图5-1学号为0001的学生的视图信息createviewv_stu_gasselectstudent_info.学号,姓名,课程名称,分数fromstudent_info,curriculum,gradewherestudent_info.学号=grade.学号andcurriculum.课程编号=grade.课程编号12.分别使用SQLServer管理平台和Transact-SQL语句修改视图v_stu_c,使之显示学号、姓名、每个学生所学课程数目。4/6alterviewv_stu_casselectstudent_info.学号,姓名,count(课程编号)as课程数目fromgradeinnerjoinstudentsdb.dbo.student_infoongrade.学号=student_info.学号groupbystudent_info.学号,姓名13.使用Transact-SQL语句ALTERVIEW修改视图v_stu_i,使其具有列名学号、姓名、性别。alterviewv_stu_iasselect学号,姓名,性别fromstudentsdb.dbo.student_info14.使用系统存储过程sp_rename将视图v_stu_i更名为v_stu_info。sp_renamev_stu_i,v_stu_info15.利用视图v_stu_i为student_info表添加一行数据:学号为0015、姓名为陈婷、性别为女。insertintov_stu_ivalues('0015','陈婷','女')16.利用视图v_stu_i删除学号为0015的学生记录。deletefromv_stu_iwhere学号='0015'17.利用视图v_stu_g修改姓名为刘卫平的学生的高等数学的分数为84。updatev_stu_gset分数='84'where姓名='刘卫平'and课程名称='高等数学'18.使用Transact-SQL语句DROPVIEW删除视图v_stu_c和v_stu_g。dropviewv_stu_c,v_stu_g5/6六、实验思考1.比较通过视图和基表操作表中数据的异同。在数据修改,查询等方面视图与表基本相同。但视图是虚拟表,并不储存数据2.可更新视图必须满足哪些条件。(1)任何修改(包括UPDATE、INSERT和DELETE语句)都只能引用一个基本表的列。(2)视图中被修改的列必须直接引用表列中的基础数据。不能通过任何其他方式对这些列进行派生,如通过聚合函数、计算(如表达式计算)、集合运算等。(3)被修改的列不受GROUPBY、HAVING、DISTINCT或TOP子句的影响3.什么是索引?SQLServer2008中有聚集索引和非聚集索引,简单叙述它们的区别。聚集索引和非聚集索引,简单叙述它们的区别?索引是对数据库表中一列或多列的值进行排序的一种结构。一个表中只能有一个聚集索引,但是可以有249个非聚集索引。聚集索引查找数据比非聚集索引要快很多,但是会比非聚集索引所占空间要大很多4.能否在视图上创建索引?不能七、总结及心得体会:视图与表类似,在选择与修改上基本相同八、对本实验过程及方法、手段的改进建议:教师评语6/6及成绩指导教师签名年月日
本文标题:数据库实验五 索引和视图
链接地址:https://www.777doc.com/doc-4455443 .html