SQL数据库实验报告-实验六.doc

上传人:b****1 文档编号:244288 上传时间:2022-10-07 格式:DOC 页数:8 大小:381.85KB
下载 相关 举报
SQL数据库实验报告-实验六.doc_第1页
第1页 / 共8页
SQL数据库实验报告-实验六.doc_第2页
第2页 / 共8页
SQL数据库实验报告-实验六.doc_第3页
第3页 / 共8页
SQL数据库实验报告-实验六.doc_第4页
第4页 / 共8页
SQL数据库实验报告-实验六.doc_第5页
第5页 / 共8页
点击查看更多>>
下载资源
资源描述

SQL数据库实验报告-实验六.doc

《SQL数据库实验报告-实验六.doc》由会员分享,可在线阅读,更多相关《SQL数据库实验报告-实验六.doc(8页珍藏版)》请在冰豆网上搜索。

SQL数据库实验报告-实验六.doc

7

第1部分Error!

Notextofspecifiedstyleindocument.

北京工业大学

数据库实验报告

存储过程和触发器

姓名:

邱健康

学号:

09521320

专业:

电信

实验8存储过程和触发器

1.实验目的

(1)掌握通过SQLServer管理平台和Transact-SQL语句CREATEPROCEDURE创建存储过程的方法和步骤。

(2)掌握使用Transact-SQL语句EXECUTE执行存储过程的方法。

(3)掌握通过SQLServer管理平台和Transact-SQL语句ALTERPROCEDURE修改存储过程的方法。

(4)掌握通过SQLServer管理平台和Transact-SQL语句DROPPROCEDURE删除存储过程的方法。

(5)掌握通过SQLServer管理平台和Transact-SQL语句CREATETRIGGER创建触发器的方法和步骤。

(6)掌握引发触发器的方法。

(7)掌握使用SQLServer管理平台或Transact-SQL语句修改和删除触发器。

2.实验内容及步骤

(1)在查询设计器中输入以下代码,创建一个利用流控制语句的存储过程letters_print,该存储过程能够显示26个小写字母。

CREATEPROCEDUREletters_print

AS

DECLARE@countint

SET@count=0

WHILE@count<26

BEGIN

PRINTCHAR(ASCII('a')+@count)

SET@count=@count+1

END

单击查询分析器的“执行查询”按钮,查看studentsdb数据库的存储过程是否有letters_print。

使用EXECUTE命令执行letters_print存储过程。

(2)输入以下代码,创建存储过程stu_info,执行时通过输入姓名,可以查询该姓名对应的学生的各科成绩。

CREATEPROCEDUREstu_info@namevarchar(40)

AS

SELECTa.学号,姓名,课程编号,分数

FROMstudent_infoaINNERJOINgradeta

ONa.学号=ta.学号

WHERE姓名=@name

使用EXECUTE命令执行存储过程stu_info,其参数值为“马东”。

(3)使用studentsdb数据库中的student_info表、curriculum表、grade表。

①创建一个存储过程stu_grade,查询学号为0001的学生的姓名、课程名称、分数。

②执行存储过程stu_grade,查询0001学生的姓名、课程名称、分数。

③使用系统存储过程sp_rename将存储过程stu_grade更名为stu_g。

(4)使用student_info表、curriculum表、grade表。

①创建一个带参数的存储过程stu_g_p,当任意输入一个学生的姓名时,将从3个表中返回该学生的学号、选修的课程名称和课程成绩。

②执行存储过程stu_g_p,查询“刘卫平”的学号、选修课程和课程成绩。

③使用系统存储过程sp_helptext,查看存储过程stu_g_p的文本信息。

(5)使用student_info表。

①创建一个加密的存储过程stu_en,查询所有男学生的信息。

②执行存储过程stu_en,查看返回学生的情况。

③使用Transact-SQL语句DROPPROCEDURE删除存储过程stu_en。

(6)使用grade表。

①创建一个存储过程stu_g_r,当输入一个学生的学号时,通过返回输出参数获取该学生各门课程的平均成绩。

②执行存储过程stu_g_r,输入学号0002。

③显示0002号学生的平均成绩。

(7)输入以下代码,复制student_info表命名为stu2,为stu2表创建一个触发器stu_tr,当stu2表插入一条记录时,为该记录生成一个学号,该学号为学号列数据的最大值加1。

--复制student_info表命名为stu2

SELECT*INTOstu2FROMstudent_info

GO

--为stu2表创建一个INSERT型触发器stu_tr

CREATETRIGGERstu_tr

ONstu2FORINSERT

AS

DECLARE@maxchar(4)

SET@max=(SELECTMAX(学号)FROMstu2)

SET@max=@max+1

UPDATEstu2SET学号=REPLICATE('0',4-len(@max))+@max

FROMstu2INNERJOINinsertedonstu2.学号=inserted.学号

执行以上代码,查看studentsdb数据库中是否有stu2表,展开stu2,查看其触发器项中是否有stu_str触发器。

在查询设计器的编辑窗口输入以下代码:

INSERTINTOstu2(学号,姓名,性别)VALUES('0001','张主','女')

运行以上代码,查看stu2表的变化情况,为什么插入记录的学号值发生了改变?

答:

因为触发器中,设置要插入的学号为已插入数据中最大学号值+1,一旦插入就执行.

(8)为grade表建立一个名为insert_g_tr的INSERT触发器,当用户向grade表中插入记录时,如果插入的是在curriculum表中没有的课程编号,则提示用户不能插入记录,否则提示记录插入成功。

在进行插入测试时,分别输入以下数据:

学号课程编号分数

0004000376

0005000769

观察插入数据时的运行情况,说明为什么?

答:

因为触发器规定若curriculum表中没有要插入的课程编号,则不允许插入,并回滚.

(9)为curriculum表创建一个名为del_c_tr的DELETE触发器,该触发器的作用是禁止删除curriculum表中的记录。

(10)为student_info表创建一个名为update_s_tr的UPDATE触发器,该触发器的作用是禁止更新student_info表中的“姓名”字段的内容。

(11)使用Transact-SQL语句DROPTRIGGER删除update_s_tr触发器。

3.实验思考

(1)用系统存储过程sp_helptext查看系统存储过程是怎么编写出来的。

USEAdventureWorks2012;

GO

SELECT

OBJECT_DEFINITION(OBJECT_ID(N'AdventureWorks2012.dbo.uspLogError'));

调用时会找到对应的对象ID,来查看系统存储过程.

(2)用系统存储过程sp_helptrigger查看前面各触发器的类型。

答:

sp_helptrigger'table''type';

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高中教育 > 初中教育

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1