实验七 存储过程及应用完整版含截图

合集下载

实验7_存储过程应用初步

实验7_存储过程应用初步

《数据库原理及应用》课程实验报告实验名称存储过程应用初步实验序号实验日期班级学号姓名院系计算机科学与信息工程学院专业计算机科学与技术指导教师成绩一、实验目的和要求1. 理解存储过程的作用;2.初步掌握存储过程的创建方法;3.初步掌握存储过程的执行方法。

4. 这个实验所涉及的容不属于《数据库原理及应用》课知识,是扩充知识,主要是为即将到来的课程设计做部分准备工作。

二、实验预习容1.上网查找资料---存储过程是数据库中的一个怎样的对象;主要应用在哪些方面;存储过程的类型等基本知识。

2.创建存储过程的方法,包括有参数和无参数的存储过程。

其中可能涉及到变量、系统函数SQL控制流语句等容。

三、实验项目摘要1.针对“图书-借阅”涉及的5表,自行设计3个存储过程(要有实际意义),执行它们,看结果是否是你所需要的;2.针对“供应”涉及的4表,设计3个存储过程(要有实际意义),执行它们,看结果是否是你所需要的。

说明:设计的存储过程不可以太过简单(如只有一个简单查询),要会设计带参数的存储过程。

同学们可以根据自己对知识的掌握情况,自行决定如何设计。

四、实验结果与分析1.(1)创建(无参数)查询‘文学’类图书中出版时间最早的最早的图书信息的存储过程并执行:1、书写T-SQL语句,创建过程一:CREATE PROCEDURE GUOCHENG_ONE AS/*新建过程一*/SELECT图书名,作者,FROM BOOKS,BOOKCATEGORYWHERE出版日期IN(SELECT MIN(出版日期)FROM BOOKSWHERE BOOKS.种类编号=BOOKCATEGORY.种类编号AND种类名称='文学')/*T-SQL语句*/GOII、执行过程一:EXECUTE GUOCHENG_ONE /*执行该存储过程功能*/(或者:EXEC GUOCHENG_ONE )(2)(单个参数)查询:设置一个存储过程GUOCHENG_TWO,通过指定可变的读者,显示其所借阅的图书的图书名:I、先以一个“具体的”书写T-SQL语句,检验语法错误;无误后以变量代替“具体的”,进而创建过程二:SELECT图书名FROM BOOKSWHERE图书编号IN(SELECT图书编号FROM BORROWWHERE读者编号IN(SELECT读者编号FROM READERSWHERE='于志强'))CREATE PROCEDURE GUOCHENG_TWO NAME varchar(10)AS/*新建过程二*/SELECT图书名FROM BOOKSWHERE图书编号IN (SELECT图书编号FROM BORROWWHERE读者编号IN (SELECT读者编号FROM READERSWHERE=NAME ))GO/*过程功能*/II、执行上述过程,即随意指定读者,查询其借阅图书的图书名:EXECUTE GUOCHENG_TWO NAME='明'/*执行该存储过程功能*/EXECUTE GUOCHENG_TWO NAME='明'/*执行该存储过程功能*/(3)设置(多个参数)插入一条记录的过程;完成后并执行该过程将:“读者编号:1243;:翟萌;种类编号:2;工作单位:交通大学;住址:桃苑小区3-415;联系:83839228;登记日期:2014-04-15;性别:男”这些容添加到到表READERS中:I、创建向表READER插入记录的过程如下:CREATE PROCEDURE GUOCHENG_THREEREADERS_NUMBER nchar(10),NAME varchar(20),RANGE_NUMBER int,COMPANY varchar(50), ADD varchar(100),TEL varchar(20),DATE datetime,SEX char(2)AS/*新建过程三*/INSERT INTO READERS VALUES(READERS_NUMBER,NAME,RANGE_NUMBER ,COMPANY,ADD,TEL,DATE,SEX)/*过程功能*/GOII、执行该过程,将记录插入到表中:EXECUTE GUOCHENG_THREEREADERS_NUMBER='1243',NAME='翟萌',RANGE_NUMBER='2',COMPANY='交通大学', ADD='桃苑小区-415',TEL='83839228',DATE='2014-04-15',SEX='男'/*执行该存储过程功能*/2.(1)创建带输出参数的存储过程,要求求出零件表P中所有蓝色零件重量的平均值,并将结果通过输出变量返回给用户:I、创建具有上述功能的带输出参数的存储过程:CREATE PROCEDURE GUOCHENG_FOUR PJZ INT OUTPUTAS/*创建过程四*/SELECT PJZ=AVG(WEIGHT)FROM零件表PWHERE COLOR ='蓝'/*过程功能*/GOII、执行该过程:DECLARE PJZ INTEXECUTE GUOCHENG_FOUR PJZ OUTPUTPRINT'零件表中所有蓝色零件的平均重量为'+STR(PJZ)GO(2)创建带输入输出参数的存储过程,要求求出“用户指定的供应商”提供给“用户指定的工程”的”所有零件重量”的平均值,并将结果通过输出变量返回给用户:I、创建具有上述功能的带输入输出参数的存储过程:CREATE PROCEDURE GUOCHENG_FIVE GYSN NCHAR(10),GCN NCHAR(10),PJZ INT OUTPUTAS/*创建过程四*/SELECT PJZ=AVG(WEIGHT)FROM零件表PWHERE PN IN(SELECT PNFROM供应关系表SPJWHERE SN IN(SELECT SNFROM供应关系表SPJWHERE SN=GYSN)AND JN IN(SELECT JNFROM供应关系表SPJWHERE JN=GCN))/*过程功能*/GOII、假设用户指定供应商为S4,工程为J4,执行上述过程:DECLARE PJZ INTEXECUTE GUOCHENG_FIVE 'S5','J4',PJZ OUTPUTPRINT'零件的平均值为'+STR(PJZ)GO(3)(无参数)更新“供应商表”用户指定值的供应表信息:I、创建具有上述功能的存储过程:CREATE PROCEDURE GUOCHENG_SIX GYSN NCHAR(10),GYSNAME NCHAR(10),CSM VARCHAR(50)AS/*创建过程六*/UPDA TE供应商表SSET SNAME=GYSNAME,CITY=CSMWHERE SN=GYSN /*过程功能*/GOII、指定S4,修改名称为“SN8”,城市为“土耳其”:附:之前实验报告修改实验五1.1)查询“计算机科学”这类图书中的定价最高的图书书名和定价;SELECT图书名,价格AS定价FROM Books,BookCategoryWHERE价格=(SELECT MAX(价格)FROM BooksWHERE Books.种类编号=BookCategory.种类编号AND种类名称='计算机科学')实验六3.导入“图书借阅”5表的关系图;导入供应商等四表的关系图。

实验七 存储过程及应用完整版含截图

实验七 存储过程及应用完整版含截图

实验七存储过程及应用1.实验目的1、理解存储过程的概念。

2、掌握存储过程的使用方法。

2.实验要求1.建立如下的存储过程(基于前面实验建立的表和插入的数据,并为每个存储过程设计返回的状态值):(1)按要求设计完成如下功能的存储过程。

①查询平均分数在x到y范围内的学生信息。

说明:该存储过程有两个参数;要求查询的学生信息包括学号、姓名、院系名称和平均分数。

②更新操作,以学号、课程编号和考试成绩作参数更新指定学生和课程的考试成绩,并返回该学生的平均成绩。

(2)自行再分别设计一个完成查询和完成操作功能的存储过程(在实验报告中要准确描述功能需求)。

(3)在客户端以存储过程和输入SQL语句的方式分别执行相同的查询或操作,比较使用和不使用存储过程的区别。

3、实验过程(1)①查询平均分数在x到y范围内的学生信息create procedure cc711@x smallint,@y smallintasselect学生.学号,学生.姓名,院系.名称,学生.平均成绩from学生join院系on学生.院系=院系.编号where学生.平均成绩between@x and@yEXECUTE cc71160,90②更新操作,以学号、课程编号和考试成绩作参数更新指定学生和课程的考试成绩,并返回该学生的平均成绩create procedure mcc712@xh nchar(8),@kcbh nchar(8),@cj intasupdate选课set成绩=@cj where学号=@xh and课程编号=@kcbhdeclare@pjcj intselect@pjcj=AVG(成绩)from选课where学号=@xhreturn@pjcjdeclare@avg intexecute@avg=mcc7122,5,98print'更新后平均成绩:'+str(@avg,6)(2)自行再分别设计一个完成查询和完成操作功能的存储过程(在实验报告中要准确描述功能需求)。

数据库应用基础实验报告7

数据库应用基础实验报告7

数据库应用基础实验报告
实验七存储过程创建与应用
班级 2009123 学号 2009 姓名
一、实验目的
使学生理解存储过程的概念, 掌握创建存储过程的使用、执行存储过程和查看、修改、删除存储过程的方法。

二、实验内容
(1)利用SQL Server ManagementStudio创建存储过程book_db, 要求实现如下功能: 在“图书信息系统”数据库中查询书名中包含“数据库”3个字的图书的图书编号和名称;调用存储过程book_db;
(2)利用SQL命令窗口创建名为proc_exp的带参存储过程, 要求实现: 从图书表中返回指定图书编号的图书的所有信息。

调用存储过程proc_exp, 输入图书编号, 显示图书的所有信息。

(3)修改存储过程proc_exp, 为按照图书的书名精确匹配查找图书信息。

(4)删除刚刚创建的book_db和proc_exp两个存储过程。

三、问题讨论
1. 相比在本地存储SQL程序, 使用存储过程有什么优点?
答:1, 允许标准组件式编程;2, 能够实现较快的执行速度;3, 减少网络流量;4, 可以作为一种安全机制来充分利用。

2. 触发器的作用是什么?
答: 触发器的作用是实现由主键和外键所不能保证的复杂的参照完整性和数据一致性。

存储过程的使用 实验报告

存储过程的使用   实验报告
GO
USEypp7
--声明四个变量,用于保存输入和输出参数
DECLARE@KECHENGMINGvarchar(20)
DECLARE@AVGCHENGJI1tinyint
DECLARE@MAXCHENGJI1tinyint
DECLARE@MINCHENGJI1tinyint
--为输入参数赋值
SELECT@KECHENGMING='高等数学'
--声明四个变量,用于保存输入和输出参数
DECLARE@KECHENGMINGvarchar(20)
DECLARE@AVGCHENGJI1tinyint
DECLARE@MAXCHENGJI1tinyint
DECLARE@MINCHENGJI1tinyint
--为输入参数赋值
SELECT@KECHENGMING='计算机基础'
1.使用if exists语句,如果存储过程“单科成绩分析”存在,就将其删除;
2.使用create proc语句创建存储过程;
3.定义所需要的输入参数和输出参数;
4.声明4个变量来保存输入和输出参数;
5.执行存储过程并显示结果。
同时,值得注意的是,在创建存储过程时,应该注意一些细节,如单词的拼写要准确无误,程序中用的是单引号而不是双引号等等。
--执行存储过程
EXEC单科成绩分析@KECHENGMING,
@AVGCHENGJI1OUTPUT,
@MAXCHENGJI1OUTPUT,
@MINCHENGJI1OUTPUT
--显示结果
SELECT@KECHENGMINGAS课程名,@AVGCHENGJI1AS平均成绩,@MAXCHENGJI1AS最高成绩,

实验07_使用T-SQL编写存储过程和函数实验报告

实验07_使用T-SQL编写存储过程和函数实验报告

北京理工大学珠海学院实验报告ZHUHAI CAMPAUS OF BEIJING INSTITUTE OF TECHNOLOGY 班级学号姓名指导教师成绩实验题目使用T-SQL编写存储过程和函数实验时间一实验目的1. 理解存储过程的概念、使用方式;2. 熟悉使用T-SQL编写存储过程来进行数据库应用程序的设计;3. 掌握SQL Server中自定义函数的概念,熟悉自定义函数的类型;4. 能创建相关的自定义函数,解决T-SQL程序设计中的相关问题。

二实验工具SQL Server 2008利用SQL Server 2008 SSMS及其SQL新建查询编辑器,使用T-SQL编写存储过程和函数。

三实验内容和要求1.建立学生-课程数据库,其中包含学生表Student(Sno,Sname,Ssex,Sage,Sdept)、课程表:Course(Cno,Cname,Cpno,Ccredit)和学生选课表:SC(Sno,Cno,Grade);编写相应的存储过程,完成下面的功能:(1)编写一个存储过程,可以查询指定系的学生的选课信息,列出学号、姓名、所在系、课程名和成绩等内容。

调用该存储过程,测试执行结果。

(2)编写一个存储过程,返回指定课程的平均分。

调用该存储过程,测试执行结果。

(3)编写一个存储过程,可以查询指定系指定成绩等级的学生的选课信息,列出学号、姓名、所在系、课程名和成绩等内容。

调用该存储过程,测试执行结果。

(成绩等级为优、良、中、及格、不及格,其中成绩在90分到100分之间为‘优’,在80分到89分之间为‘良’,在70分到79分之间为‘中’,在60分到69分之间为‘及格’,在0分到59分之间为‘不及格’。

)要求:提交创建存储过程的SQL脚本,并标注必要的注释。

保证程序能够正确编译和运行,并有相应的测试代码。

2. 自定义标量函数假设有一家生产的集装箱的公司,生产一些不同型号的集装箱,存储集装箱信息的表如下所示。

实验7 存储过程和触发器

实验7  存储过程和触发器

实验7 存储过程和触发器二、背景知识(1)存储过程概述:存储过程是SQL语句和可选控制流程语句的预编译集合,它以一个名称存储并作为一个单元处理。

存储过程存储在数据库内,可由应用程序通过一个调用执行。

存储过程可以接受参数,输出参数,返回单个或多个结果集,也可以返回一个值。

存储过程具有以下优点:●可以在一个存储过程中,执行一系列SQL语句。

●存储过程可以嵌套调用,以简化语句的描述●存储过程在创建时即在服务器上进行编译,所以执行起来比单个SQL语句快,并且能减少网络通信的负担。

●存储过程中的参数可以具有默认值,默认值必须为常量或者NULL。

(2)触发器概述:触发器是一种特殊类型的存储过程,常用作数据完整性约束。

一个系统有三类触发器,分别为:INSERT触发器、UPDATE触发器和DELETE触发器。

通常INSERT、UPDATE触发器被用来检查插入或者修改后的数据是否满足要求。

DELETE触发器一般用作级联删除或记录外键的删除操作。

当对指定表执行INSERT、UPDATE、DELETE时,相应的触发器会自动执行。

触发器可以包含复杂的T-SQL语句。

一个表可以有多个触发器。

在触发器执行的时候,会产生两个临时表:INSERTed表和deleted 表。

它们的结构和触发器所在的表的结构相同,SQLSERVER自动创建和管理这些表。

在对触发器的表进行操作时,系统执行过程如下:●执行INSERT操作,插入到触发器表中的新行同时被插入到INSERTed表中。

●执行DELETE操作,从触发器表中删除的行同时被插入到deleted 表中。

●执行UPDATE操作,先从触发器表中删除旧行,然后再插入新行。

其中,被删除的旧行,同时被插入到deleted表中;插入的新行,同时被插入到INSERTed表中。

触发器可以使用这两个临时表测试数据修改的效果及设置触发器操作的条件。

触发器具有以下优点:●触发器可通过数据库中的相关表实现级联更改。

数据库原理与应用(存储过程与触发器的应用)

数据库原理与应用(存储过程与触发器的应用)

《数据库原理与应用》实验报告题目:实验七:存储过程与触发器的应用学号:1148028姓名:沈宇杰日期:2013/5/30实验预习情况:一:实验目的:①:掌握创建存储过程的方法和步骤②:掌握存储过程的使用方法③:掌握创建触发器的方法和步骤④:掌握触发器的使用方法二:实验内容:①:存储过程的创建、执行和删除②:触发器的创建、执行和删除三:实验示例:一:创建触发器:对于STUDENT数据库,表STUDENT的CLASS_ID列与表CLASS的CLASS_ID满足下列参照完整性规则:7.1创建触发器A.向STUDENT插入或修改一记录时,该字段在STUDENT表中的对应值也做相应的修改B.修改CLASS表的CLASS_ID字段值时,该字段在STUDENT表中对应值也做相应的修改C.删除CLASS表中一记录的同时删除该记录CLASS_ID字段值在STUDENT表中对应的记录在查询分析器编辑窗口输入下列触发器的代码并执行。

①:向STUDENT表中插入或修改一记录时,通过触发器检查记录的CLASS_ID值在CLASS表中是否存在,若不存在,则取消插入或删除操CREATE TRIGGER STUDENTINS ON DBO.STUDENTFOR INSERT,UPDATEAS BEGINIF(SELECT INS.CLASS_ID FROM inserted INS)NOT IN(SELECT CLASS_ID FROM CLASS)ROLLBACKENDGOAFTER指定DML触发器仅在触发SQL语句中指定的所有操作都已成功执行时才被触发。

所有的引用级联操作和约束检查也必须在激发此触发器之前成功完成。

如果仅指定FOR关键字,则AFTER为默认值。

不能对视图定义AFTER触发器。

注意:书上的P162页的语法和SQL SERVER2008中的语法可能不大一样,SQL SERVER2008中并没有BEFORE、FOR EACH ROW等关键字。

007-实验七存储过程与触发器(实验报告内容)

007-实验七存储过程与触发器(实验报告内容)

实验七存储过程与触发器(实验报告)一、目的1.掌握存储过程和触发器的基本概念和功能。

2.掌握创建、管理存储过程的方法。

3.掌握创建、管理触发器的方法。

二、实验内容(1)完成下列操作1.利用SQL Server Management Studio创建一个查询过程ProNum,查询每个班级中学生的人数,按班级号升序排列。

2.利用Transact-SQL语句创建一个带有参数的存储过程ProInsert,向score表插入一条选课记录,并查询该学生的姓名、选修的所有课程名称、平时成绩和期末成绩。

3.利用Transact-SQL语句创建一个存储过程ProAvg,查询指定班级指定课程的平均分。

班级号和课程名称由输入参数给定,计算出的平均分通过输出参数返回。

若该存储过程存在,则删除后重建。

4.利用SQL Server Management Studio创建一个AFTER触发器trigsex,当插入或修改student表中性别字段sex时,检查数据是否只为‘男’或‘女’。

5.利用Transact-SQL语句创建一个AFTER数据库trigforeign,当向score表中插入或修改记录时,如果插入或修改的数据与student表中数据部匹配,即没有对应的学号存在,则将此记录删除。

6.利用Transact-SQL语句创建一个AFTER触发器trigclassname,当向class表中插入或修改数据时,如果出现班级名称重复则回滚事务。

若该触发器存在,则删除后重建。

(2)完成实验报告三、实验环境SQL2005。

四、实验原理1.理解存储过程。

2.掌握触发器的使用。

五、实验报告将实验内容作为实验报告完成。

六、实验小结。

存储过程及其实例演示

存储过程及其实例演示

存储过程及其实例演⽰概念存储过程存储过程是为了完成特定功能的SQL语句的集合。

包括了⼀些流程控制语句及数据类型。

种类⾃定义存储过程创建1.使⽤CREATE PROCEDURE创建存储过程CREATE PROCEDURE <Procedure_Name, sysname, ProcedureName>-- Add the parameters for the stored procedure here<@Param1, sysname, @p1> <Datatype_For_Param1, , int> = <Default_Value_For_Param1, , 0>,<@Param2, sysname, @p2> <Datatype_For_Param2, , int> = <Default_Value_For_Param2, , 0>ASBEGIN-- SET NOCOUNT ON added to prevent extra result sets from-- interfering with SELECT statements.SET NOCOUNT ON;-- Insert statements for procedure hereSELECT <@Param1, sysname, @p1>, <@Param2, sysname, @p2>ENDGOps:procedure_name 存储过程的名称。

最长为128个字符sysname:存储过程的参数。

相当于数据类型nvarchar(128)。

相见:@param1:存储过程中使⽤到的参数。

@Datatype:参数的数据类型。

另外⼤家可以看到这⾥的SQL语句都是⼤写的。

这是因为SQL语⾔在执⾏的时候是先转化为⼤写再去执⾏,对于⼀些⼩的程序这些转化的时间可以忽略,但是当⼀些⼤型的数据处理的时候就会浪费许多时间。

SQL实验7:使用存储过程

SQL实验7:使用存储过程
The Description of toy: A giant Blue Whale w
The Price of toy : 8.99
cOrderNo cToyId siQty cGiftWrap cWrapperId vMessage mToyCost
-----------------------------------------------------------------------------
createPROCproc8(@echar(6))
AS
BEGIN
IF(SELECTmTotalCostFROMOrdersWHEREcOrderNo=@e)>60BEGIN
SELECT*
FROMOrdersWHEREcOrderNo=@e
RETURN0
END
ELSE
BEGIN
PRINT'No more than 60'
ifexists(select*fromToyswherecToyId=@toyid)
begin
select@toyName=vToyName,@TOyDescription=vToyDescription,
@toyrate=mToyRate
fromToyswherecToyId=@toyid
return0
wherecToyId=@toyid
end
else
print'No record for the given Toyid'
end
指导教师
日期
注:请用A4纸书写,不够另附纸。第页,共页
end
else
return1
end
createprocproc11@toyidchar(6)='000001',

实验7存储过程

实验7存储过程

实验7 存储过程一、实验目的与要求1.掌握交互式创建存储过程的方法。

2.掌握用T-SQL创建存储过程的方法。

3.掌握执行存储过程的方法。

4.掌握修改存储过程的方法,而且不改变权限。

5.掌握交互式删除存储过程的操作。

6.掌握用SQL删除存储过程的方法。

二、实验内容1.交互式创建并执行存储过程Pro_Qsinf:通过学生的学号来查询该学生的姓名、年龄和所在系。

默认学号是200215121。

2.用T-SQL创建并执行存储过程Pro_Qgrade:通过学生的姓名和课程名来查询该学生该课程的成绩。

3.交互式修改存储过程Pro_Qsinf。

4.用SQL修改存储过程Pro_Qsinf。

5.交互式删除存储过程Pro_Qsinf。

6.用SQL删除存储过程Pro_Qgrade。

三、实验步骤1. 交互式创建并执行一存储过程(1)创建存储过程Pro_Qsinf:通过学生的学号来查询该学生的姓名、年龄和所在系。

①打开创建存储过程窗口。

在“对象资源管理器”中,依次展开“数据库”->“学生-课程”->“可编程性”->“存储过程”节点,右击“存储过程”,选择“新建存储过程”命令,如图1所示。

打开存储过程编辑窗口,并包含模板语句,如图2所示。

②修改模板语句。

将模板语句修改为图3所示的SQL语句。

③语法检查。

单击工具栏中的分析按钮,在“结果”窗口中显示“命令已成功完成”。

④保存存储过程。

单击工具栏中的执行按钮,保存创建的存储过程。

⑤查看数据库学生-课程中的存储过程对象。

在对象资源管理器中,右击数据库学生-课程中的“存储过程”节点,选择“刷新”命令,展开“存储过程”节点,查看新建的存储过程Pro_Qsinf,如图4所示。

图1 选择“新建存储过程”命令图2 存储过程编辑窗口图3 创建存储过程Pro_Qsinf图4 数据库学生-课程中的存储过程(2)执行存储过程Pro_Qsinf。

查询并显示默认学号200215121和学号为200215122的学生姓名、年龄和所在系。

实验七存储过程

实验七存储过程

实验七存储过程
实验7存储过程
1,实验要求和目的
1,掌握创建存储过程的基本方法
2。

实验完成后写一份实验报告。

要求:在实验报告的“实验源代码和结果”一节中填写T-SQL语句代码和执行结果
2,实验内容
1,根据要求创建存储过程:
(1)创建存储过程,用于执行后检索学生的基本信息(检索字段有:学号、姓名、系)
(2)创建一个存储过程,该过程可以在执行后检索数据库分数大于60分的所有学生的学号和姓名。

(3)创建一个存储过程,可以执行该过程来查询任何学生编号的学生姓名、性别、年龄和系。

(4)创建存储过程时,任何记录都可以在执行过程中插入到“学生基本信息表”(表名定制)中。

(5)创建一个可执行的存储过程以输出:参加任何课程的学生人数2。

存储过程修改(使用ALTER关键字):
(1)修改问题(2)中的存储过程,修改后的存储过程可以检索数据库分数大于80分的所有男生的学生编号和姓名
(2)修改问题(3)中存储过程,修改后的存储过程可以更新学习
的任何学生的姓名(注意:update关键字用于更新表中的数据。

具体格
式见教科书第25页的“3.3.2数据修改”。

)
(3)本节中问题(2)的存储过程。

修改后的存储过程可以更新任何课程中任何学生的分数。

实验7-存储过程

实验7-存储过程
• 执行此存储过程: EXEC p_StudentGrade1
Student ( Sno, Sname, Ssex, Sage, Sdept )
Course ( Cno, Cname, Credit, Semster )
示例 Sc ( Sno, Cno, Grade )
• 例2.带输入参数的存储过程。查询某个指定系学生的 考试情况,列出学生的姓名、所在系、课程名和考试成
Student ( Sno, Sname, Ssex, Sage, Sdept ) Course ( Cno, Cname, Credit, Semster )
参数传递方式 Sc ( Sno, Cno, Grade )
• 按参数位置传值
– 实参的排列顺序与创建存储过程时参数定义 的顺序一致。
EXEC p_StudentGrade3 '吴宾', '高等数学'
存储过程功能
• 接受输入参数并以输出参数的形式将多个值 返回给调用者。
• 包含执行数据库操作的语句。 • 将查询语句执行结果返回到客户端内存中。
存储过程优点
• 允许模块化程序设计
– 只需创建一次并存储在数据库中,就可以在应 用程序中反复调用该存储过程
• 改善性能
– 在创建存储过程时对代码进行分析和优化,并 在第一次执行时进行语法检查和编译,将编译 好的可执行代码存储在内存的一个专门缓冲区 中,以后再执行此存储过程时,只需直接执行 内存中的可执行代码即可。
2.修改存储过程
ALTER PROC [EDURE] 存储过程名
[ { @参数名 数据类型 } [ = default ]
[OUTPUT]
] [ , ... n ]

实验七 存储过程与触发器

实验七 存储过程与触发器

实验七存储过程与触发器实验七存储过程与触发器实验七存储过程与触发器一、建立一个名叫“proc_1”的存储过程,用作查阅学生表的所有信息。

然后调用该存储过程。

二、创建一个名为“proc_2”的存储过程,用于向学生表的所有字段添加一条记录,记录内容由调用时同意。

然后调用该存储过程。

三、创建一个名为“proc_3”的存储过程,用于删除学生表中指定学号的记录,具体学号由调用时同意。

然后调用该存储过程。

四、修改存储过程“proc_3”,用于查询不小于指定成绩的学生的基本信息,具体成绩由调用时同意。

五、选做题:建立一个名叫“proc_4”的存储过程,用作谋一个3十一位整数的反序数。

比如123的反序数为321。

createprocproc_4@aintasdeclare@bint,@cint,@tint,@sintbeginset@t=@a%10select@b=@a/10,@b=@b%10set@c=@a/100set@s=@t*100+@b*10+@cselect@sendgoexecproc_4123六、建立一个名叫“trig_1”的触发器,当向学生表中嵌入记录时,该触发器自动表明学生表的所有信息。

七、修正名叫“trig_1”触发器,当企图向学生表中嵌入、修正或删掉记录时,该触发器自动显示如下信息:“对不起,你无权进行更新操作!”。

八、修正“trig_1”的触发器,当向学生表中修正记录时,该触发器自动表明修正前(deleted)和修改后(inserted)的记录。

九、选做题:建立一个名叫“trig_4”的触发器,当向成绩表嵌入记录时,该触发器自动表明与该记录有关的学生的学号、姓名和班级。

(本题建议建立之前先推论该触发器与否存有)ifexists(selectnamefromsysobjectswherename='trig_4'andtype='tr')droptriggertri g_4gocreatetriggertrig_4on成绩表forinsertasselect学号,姓名,班级from学生表where学号in(select学号frominserted)goinsert成绩表values(“0012”,“02”,80)2、截取图片,填写如下实验过程记录表实验过程记录(特别注意:标示题号)1.2.3.4.。

实验7-存储过程应用初步讲课讲稿

实验7-存储过程应用初步讲课讲稿

实验7-存储过程应用初步《数据库原理及应用》课程实验报告GOII、执行过程一:EXECUTE GUOCHENG_ONE /*执行该存储过程功能*/(或者:EXEC GUOCHENG_ONE )(2)(单个参数)查询:设置一个存储过程GUOCHENG_TWO,通过指定可变的读者姓名,显示其所借阅的图书的图书名:I、先以一个“具体的姓名”书写T-SQL语句,检验语法错误;无误后以变量代替“具体的姓名”,进而创建过程二:①SELECT图书名FROM BOOKSWHERE图书编号IN(SELECT图书编号FROM BORROWWHERE读者编号IN(SELECT读者编号FROM READERSWHERE姓名='于志强'))②CREATE PROCEDURE GUOCHENG_TWO @NAME varchar(10)AS/*新建过程二*/SELECT图书名FROM BOOKSWHERE图书编号IN (SELECT图书编号FROM BORROWWHERE读者编号IN (SELECT读者编号FROM READERSWHERE姓名=@NAME ))GO/*过程功能*/II、执行上述过程,即随意指定读者姓名,查询其借阅图书的图书名:EXECUTE GUOCHENG_TWO @NAME='李明'/*执行该存储过程功能*/EXECUTE GUOCHENG_TWO @NAME='李明'/*执行该存储过程功能*/(3)设置(多个参数)插入一条记录的过程;完成后并执行该过程将:“读者编号:1243;姓名:翟萌;种类编号:2;工作单位:西安交通大学;住址:桃苑小区3-415;联系电话:83839228;登记日期:2014-04-15;性别:男”这些内容添加到到表READERS中:I、创建向表READER插入记录的过程如下:CREATE PROCEDURE GUOCHENG_THREE@READERS_NUMBER nchar(10),@NAME varchar(20),@RANGE_NUMBER int,@COMPANY varchar(50),@ADD varchar(100),@TEL varchar(20),@DATE datetime,@SEX char(2)AS/*新建过程三*/INSERT INTO READERSVALUES(@READERS_NUMBER,@NAME,@RANGE_NUMBER ,@COMPANY, @ADD,@TEL,@DATE,@SEX)/*过程功能*/GOII、执行该过程,将记录插入到表中:EXECUTE GUOCHENG_THREE@READERS_NUMBER='1243',@NAME='翟萌',@RANGE_NUMBER='2',@COMPANY='西安交通大学',@ADD='桃苑小区-415',@TEL='83839228',@DATE='2014-04-15',@SEX='男'/*执行该存储过程功能*/2.(1)创建带输出参数的存储过程,要求求出零件表P中所有蓝色零件重量的平均值,并将结果通过输出变量返回给用户:I、创建具有上述功能的带输出参数的存储过程:CREATE PROCEDURE GUOCHENG_FOUR @PJZ INT OUTPUTAS/*创建过程四*/SELECT @PJZ=AVG(WEIGHT)FROM零件表PWHERE COLOR ='蓝'/*过程功能*/GOII、执行该过程:DECLARE @PJZ INTEXECUTE GUOCHENG_FOUR @PJZ OUTPUTPRINT'零件表中所有蓝色零件的平均重量为'+STR(@PJZ)GO(2)创建带输入输出参数的存储过程,要求求出“用户指定的供应商”提供给“用户指定的工程”的”所有零件重量”的平均值,并将结果通过输出变量返回给用户:I、创建具有上述功能的带输入输出参数的存储过程:CREATE PROCEDURE GUOCHENG_FIVE @GYSN NCHAR(10),@GCN NCHAR(10),@PJZ INT OUTPUTAS/*创建过程四*/SELECT @PJZ=AVG(WEIGHT)FROM零件表PWHERE PN IN(SELECT PNFROM供应关系表SPJWHERE SN IN(SELECT SNFROM供应关系表SPJWHERE SN=@GYSN)AND JN IN(SELECT JNFROM供应关系表SPJWHERE JN=@GCN))/*过程功能*/GOII、假设用户指定供应商为S4,工程为J4,执行上述过程:DECLARE @PJZ INTEXECUTE GUOCHENG_FIVE 'S5','J4',@PJZ OUTPUTPRINT'零件的平均值为'+STR(@PJZ)GO(3)(无参数)更新“供应商表”用户指定值的供应表信息:I、创建具有上述功能的存储过程:CREATE PROCEDURE GUOCHENG_SIX @GYSN NCHAR(10),@GYSNAME NCHAR(10),@CSM VARCHAR(50)AS/*创建过程六*/UPDATE供应商表SSET SNAME=@GYSNAME,CITY=@CSMWHERE SN=@GYSN /*过程功能*/GOII、指定S4,修改名称为“SN8”,城市为“土耳其”:附:之前实验报告修改实验五1.1)查询“计算机科学”这类图书中的定价最高的图书书名和定价;SELECT图书名,价格AS定价FROM Books,BookCategoryWHERE价格=(SELECT MAX(价格)FROM BooksWHERE Books.种类编号=BookCategory.种类编号AND种类名称='计算机科学')实验六3.导入“图书借阅”5张表的关系图;导入供应商等四张表的关系图。

数据库原理与应用(存储过程与触发器的应用)

数据库原理与应用(存储过程与触发器的应用)

《数据库原理与应用》实验报告题目:实验七:存储过程与触发器的应用学号:1148028姓名:沈宇杰日期:2013/5/30实验预习情况:一:实验目的:①:掌握创建存储过程的方法和步骤②:掌握存储过程的使用方法③:掌握创建触发器的方法和步骤④:掌握触发器的使用方法二:实验内容:①:存储过程的创建、执行和删除②:触发器的创建、执行和删除三:实验示例:一:创建触发器:对于STUDENT数据库,表STUDENT的CLASS_ID列与表CLASS的CLASS_ID满足下列参照完整性规则:7.1创建触发器A.向STUDENT插入或修改一记录时,该字段在STUDENT表中的对应值也做相应的修改B.修改CLASS表的CLASS_ID字段值时,该字段在STUDENT表中对应值也做相应的修改C.删除CLASS表中一记录的同时删除该记录CLASS_ID字段值在STUDENT表中对应的记录在查询分析器编辑窗口输入下列触发器的代码并执行。

①:向STUDENT表中插入或修改一记录时,通过触发器检查记录的CLASS_ID值在CLASS表中是否存在,若不存在,则取消插入或删除操CREATE TRIGGER STUDENTINS ON DBO.STUDENTFOR INSERT,UPDATEAS BEGINIF(SELECT INS.CLASS_ID FROM inserted INS)NOT IN(SELECT CLASS_ID FROM CLASS)ROLLBACKENDGOAFTER指定DML触发器仅在触发SQL语句中指定的所有操作都已成功执行时才被触发。

所有的引用级联操作和约束检查也必须在激发此触发器之前成功完成。

如果仅指定FOR关键字,则AFTER为默认值。

不能对视图定义AFTER触发器。

注意:书上的P162页的语法和SQL SERVER2008中的语法可能不大一样,SQL SERVER2008中并没有BEFORE、FOR EACH ROW等关键字。

实验7存储过程和触发器

实验7存储过程和触发器

实验7存储过程和触发器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语句修改和删除触发器。

(8)掌握事务、命名事务的创建方法,了解不同类型的事务的处理情况。

2.实验内容及步骤请先附加studentsdb数据库,然后完成以下实验。

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

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

语句:CREATE PROCEDURE stu_info@name varchar(40)='刘卫平'--将@name值设为默认值'刘卫平'AS答:请完善执行EXEC stu_infoEXEC stu_info '马东'(3)使用系统存储过程sp_rename将存储过程stu_grade更名为stu_g。

答:(4)使用grade表。

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

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

实验7_存储过程应用初步

实验7_存储过程应用初步

《数据库原理及应用》课程实验报告EXECUTE GUOCHENG_ONE /*执行该存储过程功能*/(或者:EXEC GUOCHENG_ONE )(2)(单个参数)查询:设置一个存储过程GUOCHENG_TWO,通过指定可变的读者,显示其所借阅的图书的图书名:I、先以一个“具体的”书写T-SQL语句,检验语法错误;无误后以变量代替“具体的”,进而创建过程二:①SELECT图书名FROM BOOKSWHERE图书编号IN(SELECT图书编号FROM BORROWWHERE读者编号IN(SELECT读者编号FROM READERSWHERE='于志强'))②CREATE PROCEDURE GUOCHENG_TWO NAME varchar(10)AS/*新建过程二*/SELECT图书名FROM BOOKSWHERE图书编号IN (SELECT图书编号FROM BORROWWHERE读者编号IN (SELECT读者编号FROM READERSWHERE=NAME ))GO/*过程功能*/II、执行上述过程,即随意指定读者,查询其借阅图书的图书名:EXECUTE GUOCHENG_TWO NAME='明'/*执行该存储过程功能*/EXECUTE GUOCHENG_TWO NAME='明'/*执行该存储过程功能*/(3)设置(多个参数)插入一条记录的过程;完成后并执行该过程将:“读者编号:1243;:翟萌;种类编号:2;工作单位:交通大学;住址:桃苑小区3-415;联系:83839228;登记日期:2014-04-15;性别:男”这些容添加到到表READERS中:I、创建向表READER插入记录的过程如下:CREATE PROCEDURE GUOCHENG_THREEREADERS_NUMBER nchar(10),NAME varchar(20),RANGE_NUMBER int,COMPANY varchar(50), ADD varchar(100),TEL varchar(20),DATE datetime,SEX char(2)AS/*新建过程三*/INSERT INTO READERS V ALUES(READERS_NUMBER,NAME,RANGE_NUMBER ,COMPANY,ADD,TEL,DATE,SEX)/*过程功能*/GOII、执行该过程,将记录插入到表中:EXECUTE GUOCHENG_THREEREADERS_NUMBER='1243',NAME='翟萌',RANGE_NUMBER='2',COMPANY='交通大学', ADD='桃苑小区-415',TEL='83839228',DATE='2014-04-15',SEX='男'/*执行该存储过程功能*/2.(1)创建带输出参数的存储过程,要求求出零件表P中所有蓝色零件重量的平均值,并将结果通过输出变量返回给用户:I、创建具有上述功能的带输出参数的存储过程:CREATE PROCEDURE GUOCHENG_FOUR PJZ INT OUTPUTAS/*创建过程四*/SELECT PJZ=A VG(WEIGHT)FROM零件表PWHERE COLOR ='蓝'/*过程功能*/GOII、执行该过程:DECLARE PJZ INTEXECUTE GUOCHENG_FOUR PJZ OUTPUTPRINT'零件表中所有蓝色零件的平均重量为'+STR(PJZ)GO(2)创建带输入输出参数的存储过程,要求求出“用户指定的供应商”提供给“用户指定的工程”的”所有零件重量”的平均值,并将结果通过输出变量返回给用户:I、创建具有上述功能的带输入输出参数的存储过程:CREATE PROCEDURE GUOCHENG_FIVE GYSN NCHAR(10),GCN NCHAR(10),PJZ INT OUTPUTAS/*创建过程四*/SELECT PJZ=AVG(WEIGHT)FROM零件表PWHERE PN IN(SELECT PNFROM供应关系表SPJWHERE SN IN(SELECT SNFROM供应关系表SPJWHERE SN=GYSN)AND JN IN(SELECT JNFROM供应关系表SPJWHERE JN=GCN))/*过程功能*/GOII、假设用户指定供应商为S4,工程为J4,执行上述过程:DECLARE PJZ INTEXECUTE GUOCHENG_FIVE 'S5','J4',PJZ OUTPUTPRINT'零件的平均值为'+STR(PJZ)GO(3)(无参数)更新“供应商表”用户指定值的供应表信息:I、创建具有上述功能的存储过程:CREATE PROCEDURE GUOCHENG_SIX GYSN NCHAR(10),GYSNAME NCHAR(10),CSM V ARCHAR(50)AS/*创建过程六*/UPDA TE供应商表SSET SNAME=GYSNAME,CITY=CSMWHERE SN=GYSN /*过程功能*/GOII、指定S4,修改名称为“SN8”,城市为“土耳其”:附:之前实验报告修改实验五1.1)查询“计算机科学”这类图书中的定价最高的图书书名和定价;SELECT图书名,价格AS定价FROM Books,BookCategoryWHERE价格=(SELECT MAX(价格)FROM BooksWHERE Books.种类编号=BookCategory.种类编号AND种类名称='计算机科学')实验六3.导入“图书借阅”5表的关系图;导入供应商等四表的关系图。

实验7

实验7

实验7 图书馆日常事务管理系统存储过程的创建和管理1.实验目的1)掌握创建存储过程的三种方法;2)掌握存储过程的调用方法;3)掌握带参数的存储过程的创建和调用的用法;4)掌握存储过程重编译的方法;5)掌握查看存储过程信息的方法;6)掌握修改和删除存储过程的方法。

2.实验知识准备1)存储过程的定义方法;2)存储过程的调用方法;3)带参数的存储过程的创建和调用方法;4)存储过程的重编译;5)查看存储过程信息的系统存储过程的用法;6)修改、删除存储过程的T-SQL语句的用法。

3.实验要求1)若某一实验内容项目,可以由多种方法完成的,则每一种方法都要实验一遍。

2)验收实验结果,提交实验报告。

4.实验内容1)创建存储过程(1)使用企业管理器创建存储过程在TSJYMS数据库中创建一个查询图书库存量的存储过程“cx_tskcl_proc”,输出的内容包含类别号、图书编号、图书名称、库存数等数据内容。

(2)使用向导创建存储过程在TSJYMS数据库中创建一个“cx_dzxx_proc” 存储过程,该存储过程能查询出所有借书的读者信息。

(3)使用T-SQL语句创建存储过程① 在TSJYMS数据库中创建一个名为“ins_tslb_proc”的存储过程,该存储过程用于向图书类别表插入记录。

② 在TSJYMS数据库中,创建一个名为TS_CX_PROC的存储过程,它带有一个输入参数,用于接受图书编号,显示该图书的名称、作者、出版和复本数。

2)存储过程的调用① 执行cx_tskcl_proc存储过程,了解图书库存的信息。

② 执行cx_dzxx_proc存储过程,了解读者借书的情况。

③ 通过ins_tslb_proc存储过程,新增一个图书类别 ('TP311','数据库技术'),并查询结果。

④ 执行TS_CX_PROC存储过程,分别查询“99011818”、“01058589”、“07410801”等书号的图书信息。

存储过程实验

存储过程实验
假设高级数据库开发员已为你提供了一个名为Sales.SpecialOffer表,你必须进行以下指定的要求(写出下列存储过程的T-SQL语句):
在Sales架构中创建一个名为GetDiscounts的存储过程,该过程从Sales.SpecialOffer中检索以下列:Description、DiscountPct、Type、Category、StartDate、EndDate、MinQty和MaxQty。该过程应按StartDate和EndDate排序返回所有行;执行其存储过程。
该过程应检索与GetDiscounts相同的列,但是应该基于@Category和@DateToCheck参数筛选行。
使用@Category值“Reseller”以及@DateToCheck参数的默认值执行Sales.GetDiscountsForCategoryAndDate存储过程。
实验步骤
1.单击“开始”,指向“所有程序”,指向“MicrosoftSQLServer2005”,然后单击“SQL Server Management Studio”。
实现存储过程报告书名称实验71创建存储过程姓名指导教师学号日期任务清单场景adventureworks维护着一份各种产品在全年中的特价供应和折扣的列表该列表同时适用于客户和分销商
实验报告

报告书
名称
实验7-1创建存储过程
姓名
指导教师
学号
日期
任务清单
场景
Adventure Works维护着一份各种产品在全年中的特价供应和折扣的列表,该列表同时适用于客户和分销商。目前,此信息只能直接从Sales.SpecialOffer表中获得。一项新提出的要求是能够使用存储过程来检索此信息。
在Sales架构中创建名为GetDiscountsForCategory的存储过程,该过程接收名为@Category的输入参数,此参数为nvarchar数据类型,并且最多接收50个字符。该过程应检索与GetDiscounts相同的列,但是应该基于@Category参数筛选行;使用“Reseller”作为@Category值执行Sales.GetDiscountsForCatego,然后单击“连接”。
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验七存储过程及应用
1.实验目的
1、理解存储过程的概念。

2、掌握存储过程的使用方法。

2.实验要求
1.建立如下的存储过程(基于前面实验建立的表和插入的数据,并为每个存储过程设计返回的状态值):
(1)按要求设计完成如下功能的存储过程。

①查询平均分数在x到y范围内的学生信息。

说明:
该存储过程有两个参数;
要求查询的学生信息包括学号、姓名、院系名称和平均分数。

②更新操作,以学号、课程编号和考试成绩作参数更新指定学生和课程的考试成绩,并返回该学生的平均成绩。

(2)自行再分别设计一个完成查询和完成操作功能的存储过程(在实验报告中要准确描述功能需求)。

(3)在客户端以存储过程和输入SQL语句的方式分别执行相同的查询或操作,比较使用和不使用存储过程的区别。

3、实验过程
(1)①查询平均分数在x到y范围内的学生信息
create procedure cc711@x smallint,@y smallint
as
select学生.学号,学生.姓名,院系.名称,学生.平均成绩
from学生join院系on学生.院系=院系.编号
where学生.平均成绩between@x and@y
EXECUTE cc71160,90
②更新操作,以学号、课程编号和考试成绩作参数更新指定学生和课程的考试成绩,并返回该学生的平均成绩
create procedure mcc712@xh nchar(8),@kcbh nchar(8),@cj int
as
update选课set成绩=@cj where学号=@xh and课程编号=@kcbh
declare@pjcj int
select@pjcj=AVG(成绩)from选课where学号=@xh
return@pjcj
declare@avg int
execute@avg=mcc7122,5,98
print'更新后平均成绩:'+str(@avg,6)
(2)自行再分别设计一个完成查询和完成操作功能的存储过程(在实验报告中要准确描述功能需求)。

create procedure dcc721@kcmc nchar(20)
as
declare@cc721nchar(10)
select@cc721=学生.平均成绩
from学生join选课on学生.学号=选课.学号
where选课.成绩in(select MAX(成绩)
from选课where选课.课程编号in(
select课程编号from课程where学时=@kcmc))
return@cc721
declare@acc721nchar(10)
execute@acc721=dcc721'16'
print'最高分者的平均成绩'+str(@acc721)
(3)在客户端以存储过程和输入SQL语句的方式分别执行相同的查询或操作,比较使用和不使用存储过程的区别。

存储:
create procedure cc731@kcmc nchar(20)
as
select学生.学号,姓名,性别from学生join选课
on学生.学号=选课.学号
where选课.课程编号in(
select课程编号from课程
where课程名称=@kcmc)
execute cc731数据库
输入SQL语句:
select学生.学号,姓名,性别from学生join选课
on学生.学号=选课.学号where选课.课程编号in( select课程编号from课程where课程名称='数据库')
4、实验总结
存储过程比SQL的优势在于一次编译多次使用,因为在存储过程中的SQL语句是已经过了语法检查和编译的,可以直接执行;而SQL总要先进行语法解析和编译才能执行。

另外对于网络执行的话,执行相同的任务,客户端调用存储过程的代码传输量和直接执行SQL语句相比也要更少。

存储中参数的使用很重要,也容易出错。

相关文档
最新文档