SQL数据库实验报告 实验六
更新时间:2023-09-29 09:17:01 阅读量: 综合文库 文档下载
- mysql数据库实验报告推荐度:
- 相关推荐
第
1部分
北京工业大学
数据库实验报告
存储过程和触发器
姓名:邱健康 学号:09521320
专业: 电信
第1部分 错误!使用“开始”选项卡将 标题 1 应用于要在此处显示的文字。
实验8 存储过程和触发器
1.实验目的
(1)掌握通过SQL Server管理平台和Transact-SQL语句CREATE PROCEDURE创建存储过程的方法和步骤。
(2)掌握使用Transact-SQL语句EXECUTE执行存储过程的方法。
(3)掌握通过SQL Server管理平台和Transact-SQL语句ALTER PROCEDURE修改存储过程的方法。
(4)掌握通过SQL Server管理平台和Transact-SQL语句DROP PROCEDURE删除存储过程的方法。
(5)掌握通过SQL Server管理平台和Transact-SQL语句CREATE TRIGGER创建触发器的方法和步骤。
(6)掌握引发触发器的方法。
(7)掌握使用SQL Server管理平台或Transact-SQL语句修改和删除触发器。
2.实验内容及步骤
(1)在查询设计器中输入以下代码,创建一个利用流控制语句的存储过程letters_print,该存储过程能够显示26个小写字母。
CREATE PROCEDURE letters_print AS
DECLARE @count int SET @count=0 WHILE @count<26 BEGIN
PRINT CHAR(ASCII('a')+ @count) SET @count=@count +1 END
2
单击查询分析器的“执行查询”按钮,查看studentsdb数据库的存储过程是否有letters_print。
使用EXECUTE命令执行letters_print存储过程。
第1部分 错误!使用“开始”选项卡将 标题 1 应用于要在此处显示的文字。
(2)输入以下代码,创建存储过程stu_info,执行时通过输入姓名,可以查询该姓名对应的学生的各科成绩。
CREATE PROCEDURE stu_info @name varchar(40) AS
SELECT a.学号,姓名,课程编号,分数
FROM student_info a INNER JOIN grade ta ON a.学号= ta.学号 WHERE 姓名= @name
3
使用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,查询“刘卫平”的学号、选修课程和课程成绩。
第1部分 错误!使用“开始”选项卡将 标题 1 应用于要在此处显示的文字。
4
③ 使用系统存储过程sp_helptext,查看存储过程stu_g_p的文本信息。
(5)使用student_info表。
① 创建一个加密的存储过程stu_en,查询所有男学生的信息。 ② 执行存储过程stu_en,查看返回学生的情况。
③ 使用Transact-SQL语句DROP PROCEDURE删除存储过程stu_en。
第1部分 错误!使用“开始”选项卡将 标题 1 应用于要在此处显示的文字。
5
(6)使用grade表。
① 创建一个存储过程stu_g_r,当输入一个学生的学号时,通过返回输出参数获取该学生各门课程的平均成绩。
② 执行存储过程stu_g_r,输入学号0002。 ③ 显示0002号学生的平均成绩。
(7)输入以下代码,复制student_info表命名为stu2,为stu2表创建一个触发器stu_tr,当stu2表插入一条记录时,为该记录生成一个学号,该学号为学号列数据的最大值加1。
--复制student_info表命名为stu2
SELECT * INTO stu2 FROM student_info GO
--为stu2表创建一个INSERT型触发器stu_tr CREATE TRIGGER stu_tr ON stu2 FOR INSERT AS
DECLARE @max char(4)
SET @max=(SELECT MAX(学号) FROM stu2)
SET @max=@max+1
UPDATE stu2 SET 学号=REPLICATE('0',4-len(@max))+@max
执行以上代码,查看studentsdb数据库中是否有stu2表,展开stu2,查看其触发器项中是否有stu_str触发器。
FROM stu2 INNER JOIN inserted on stu2.学号=inserted.学号
第1部分 错误!使用“开始”选项卡将 标题 1 应用于要在此处显示的文字。 在查询设计器的编辑窗口输入以下代码:
INSERT INTO stu2(学号,姓名,性别) VALUES('0001','张主','女')
6
运行以上代码,查看stu2表的变化情况,为什么插入记录的学号值发生了改变? 答:因为触发器中,设置要插入的学号为已插入数据中最大学号值+1,一旦插入就执行. (8)为grade表建立一个名为insert_g_tr 的INSERT触发器,当用户向grade表中插入记录时,如果插入的是在curriculum表中没有的课程编号,则提示用户不能插入记录,否则提示记录插入成功。在进行插入测试时,分别输入以下数据:
学号 课程编号 分数
0004 0003 76 0005 0007 69
观察插入数据时的运行情况,说明为什么?
答:因为触发器规定若curriculum表中没有要插入的课程编号,则不允许插入,并回滚. (9)为curriculum表创建一个名为del_c_tr的DELETE触发器,该触发器的作用是禁止删除curriculum表中的记录。
第1部分 错误!使用“开始”选项卡将 标题 1 应用于要在此处显示的文字。
7
(10)为student_info表创建一个名为update_s_tr的UPDATE触发器,该触发器的作用是禁止更新student_info表中的“姓名”字段的内容。
(11)使用Transact-SQL语句DROP TRIGGER删除update_s_tr触发器。
3.实验思考
(1)用系统存储过程sp_helptext查看系统存储过程是怎么编写出来的。 USE AdventureWorks2012; GO
SELECT
第1部分 错误!使用“开始”选项卡将 标题 1 应用于要在此处显示的文字。
OBJECT_DEFINITION (OBJECT_ID(N'AdventureWorks2012.dbo.uspLogError')); 调用时会找到对应的对象ID,来查看系统存储过程.
(2)用系统存储过程sp_helptrigger查看前面各触发器的类型。 答: sp_helptrigger 'table' 'type';
8
正在阅读:
SQL数据库实验报告 实验六09-29
经济新常态下的财政政策对就业的影响06-21
2016年大连海事大学法律硕士复试分数线03-29
数学逻辑思维04-01
大正新修大藏经_影印原本_资源介绍05-15
2014高考数学理二轮专题突破文档:4.2空间中的平行与垂直03-02
2019版高考语文一轮复习专题六古代诗歌阅读“古诗歌阅读”综合提05-22
青春没有地平线02-14
天钢套管技术服务手册05-27
晁错知识点11-18
- 2009中西部家居博览会总体策划
- 2009 Revit 1级工程师学生用
- 天津地铁建设工程试验检测机构管理办法(TJDT-ZY-AQ-29)
- 新四年级数学暑期班第七次教案
- 机械制造企业隐患排查治理检查表 - 图文
- 2008届全国百套高考数学模拟试题分类汇编-103概率与统计解答题 -
- 职场健身防病试题及答案
- Excel操作技巧大全II - --数据输入和编辑技巧
- 南开大学2018春季《行政管理学》离线作业考核答案
- 2015年医师定考简易程序试卷及答案
- 新《预算法》对行政事业单位预算管理的挑战解读
- 轴的课件
- 电动汽车充电桩设计 毕业论文
- 必修2、选修2-1、1-1期末模拟试题2
- 桌面远程运维管理系统实施-可行性研究报告120306
- 西气东输水土保持工程工作总结 - 图文
- 正宁县基本县情及经济社会发展情况简介
- SATWE参数设置(巨详细)
- 儒家法思想研究综述
- 生活家政服务电子商务平台建设运营整合方案书【审报完稿】
- 实验
- 数据库
- 报告
- SQL
- 县域文化产业发展实践与探索
- C语言程序设计期末考试样题
- 2018年4月自考管理系统中计算机应用00051试题及答案(整理版)
- 2018届安徽省江淮名校高三第二次联考地理试题及答案 - 图文
- 高炉上料工艺分析
- 小区环境心理学分析 - 图文
- 税法实验报告
- 精品2018-2019学年高一新高考数学-函数实际应用(难度系数大)
- PerKin法制备肉桂酸实验条件的优化
- 朱岩:梦想成真的开始在中国人民大学法学院2013届毕业典礼上的发言
- 中国传统文化对现代语文教育的渗透研究
- 自检自测二(4—6)
- 功能性食品学复习题
- 支教总结教育调查报告一系列(20) - 图文
- 儒家政治思想对大学生理想信念的影响
- 《学前儿童科学教育基础》专科 试题库及答案
- 石岩公学小学部管理手册doc
- 四年级高思奥数之平均数问题含答案
- 研究报告-2018-2024年血液透析行业市场运营趋势分析及投资潜力研究(目录) - 图文
- 如何正确分析判断结构设计电算结果