文档详情

数据库系统概论实验报告八.doc

发布:2018-12-22约4.41千字共14页下载文档
文本预览下载声明
山西大学计算机与信息技术学院 实验报告 姓 名 张浩田 学 号 2014241027 专业班级 计算机科学与技术 课程名称 数据库系统概论 实验日期 2016/12/26 成 绩 指导教师 王俊红 批改日期 实验名称 实验目的: ?了解存储过程的概念和作用 ?掌握存储过程的创建、执行以及查看、修改和删除 实验原理: Transact-SQL中的存储过程,非常类似于Java语言中的方法,它可以重复调用。当存储过程执行一次后,可以将语句缓存中,这样下次执行的时候直接使用缓存中的语句。这样就可以提高存储过程的性能。 存储过程Procedure是一组为了完成特定功能的SQL语句集合,经编译后存储在数据库中,用户通过指定存储过程的名称并给出参数来执行。 存储过程中可以包含逻辑控制语句和数据操纵语句,它可以接受参数、输出参数、返回单个或多个结果集以及返回值。 由于存储过程在创建时即在数据库服务器上进行了编译并存储在数据库中,所以存储过程运行要比单个的SQL语句块要快。同时由于在调用时只需用提供存储过程名和必要的参数信息,所以在一定程度上也可以减少网络流量、简单网络负担。 三.实验设备 安装SQL SERVER2005的PC一台。 四、实验步骤: ?存储过程的创建与执行 ?存储过程的查看、修改与删除 1. 使用创建存储过程模板创建存储过程 (1)打开SQL Server Management Studio,展开节点“对象资源管理器”|“数据定义”|“可编程性”|“存储过程”,在窗口的右侧显示出当前数据库的所有存储过程。单击鼠标右键,在弹出的快捷菜单中选择“新建存储过程”命令 (2)在打开的SQL命令窗口中,系统给出了创建存储过程命令的模板 在模板中可以输入创建存储过程的T-SQL语句,按照下面的代码建立存储过程的命令模板后,单击“执行”按钮,即可创建存储过程, (3)在新建的getstudent存储过程可以通过以下代码来执行, 2. 使用SQL命令窗口创建存储过程 (1)打开SQL Server Management Studio,选择“对象资源管理器”中的“学生数据库”,然后用鼠标单击“新建查询”按钮,打开SQL命令窗口,在可编辑区输入如下代码,单击“执行”按钮即可创建存储过程, (2)新建立的getstudent_all存储过程可以通过以下代码执行,执行结果同使用创建存储过程模板创建的存储过程。 创建一个不带参数的存储过程,从Course中选择所有“Grade90”的记录,输入如下语句,单击“执行”, 创建一个带参数的存储过程,从Course中选择Grade介于65-95之间的记录,输入如下语句,单击“执行” 创建与执行带输入、输出参数的存储过程,实现显示“Course”中给定学号的信息,并输出“Course”中该学号的学生所选课程中的最高分数和最低分数,具体步骤如下: 1)单击Microsoft SQL Server Management Studio,选择“对象资源管理器”中的“数据定义”。 2)单击常用工具栏中的“新建查询”按钮,新建一个数据库引擎查询文档。 3)在数据库引擎文档中输入如下代码,单击“执行”按钮,即可创建名称为getstudent_3的存储过程 (3)存储过程创建成功后,输入如下T-SQL语句,单击“执行”按钮,执行已经创建的存储过程getstudent_3, 3. 查看存储过程 (1)使用Mircrosoft SQL Server 2005 Management Studio查看用户创建存储过程。 在使用SQL Server Management Studio中,展开指定的服务器和数据库,选择展开“可编程性”│“存储过程”节点,然后在要查看的存储过程名称上单击鼠标右键。从弹出的快捷菜单中选择“编写存储过程脚本为”│“CREATE到”│“新查询编辑器”窗口命令,即可看到存储过程的源代码。 (2)使用系统存储过程来查看用户创建的存储过程 可供使用的系统存储过程及语法格式如下: ·sp_help,用于显示存储过程的参数机器数据类型,其语法为: sp_help[[@objname=]name],参数name为要查看的存储过程的名称。 ·sp_helptext,用于显示存储过程的代码,其语法为: sp_helptext[[@objname=]name],参数name为要查看的存储过程的名称。 ·sp_depends,用于显示和存储过程相关的数据库对象,其语法为: sp_depends[[@objname=]’object’,参数object为要查看依赖关系的存储过程的名称。 ·sp_stored_procedurse,用于返回当前数据库中的存储过程列表,其语法为
显示全部
相似文档