搜档网
当前位置:搜档网 › SQL+Server存储过程编程经验技巧

SQL+Server存储过程编程经验技巧

SQL+Server存储过程编程经验技巧
SQL+Server存储过程编程经验技巧

SQL Server存储过程编程经验技巧

MSSQLServer目前正日益成为WindowNT操作系统上面最为重要的一种数据库管理系统,随着

MSSQLServer2000的推出,微软的这种数据库服务系统真正的实现了在WindowsNT/200

0系列操作系统一统天下的局面,在微软的操作系统上面,没有任何一种数据库系统能与之相抗衡,包括数据库领域的领

头羊甲骨文公司的看家数据库系统Oracle在内。不可否认,MSSQLServer最大的缺陷就是只能运行

在微软自己的操作系统上面,这一点是MSSQLServer的致命伤口。但在另一方面却也成了最好的促进剂,

促使MSSQLServer在自己仅有的“土地”上面将自己的功能发挥到了极至,最大限度的利用了Windo

wsNT系列操作系统的各种潜能!作为MSSQLServer数据库系统中很重要的一个概念就是存储过程,合

理的使用存储过程,可以有效的提高程序的性能;并且将商业逻辑封装在数据库系统中的存储过程中,可以大大提高整个

软件系统的可维护性,当你的商业逻辑发生了改变的时候,不再需要修改并编译客户端应用程序以及重新分发他们到为数

众多的用户手中,你只需要修改位于服务器端的实现相应商业逻辑的存储过程即可。合理的编写自己需要的存储过程,可

以最大限度的利用MSSQLServer的各种资源。下面我们来共同看看各种编写MSSQLServer

存储过程和使用存储过程的技巧经验!

下面我们讨论的前提都是您有过一定的MSSQLServer存储过程的编写经验,下面的各种技巧如果没有

特别注明,则同时适用于MSSQLServer7.0和MSSQLServer2000。

1、使用OUTPUT类型参数的存储过程的技巧

一般的存储过程都是直接返回一段记录集给调用者,但是有的时候我们只需要一些存储过程返回的一些参数的值,这时候

可以指定存储过程的OUTPUT参数,比如:

CreateprocedureGetName

@uidnvarchar(1),

@usernamnvarchar(10)=''output

AS

set@username='hongchao'

GO

在上面的存储过程当中我们传递进的参数是@uid,而参数@username则在调有的时候不需要传递进去。

这样,存储过程会返回给我们参数@username的值是…hongchao?。上面的都比较的容易,需要注意的

是,当在SQL2000中的时候,如果你的存储过程只有一个参数,并且这个参数是OUTPUT类型的,你必须在调

用这个存储过程的时候给这个参数一个初始的值,否则会出现调用错误的情况!

2、在存储过程中的书写注意事项

这一点在MSSQLServer7.0和MSSQLServer2000种有些地方是不一样的,也不

知道是不是微软的遗漏,那就是有些系统的关键字在不同的版本之间有所不同,比如关键字level,同样的一句话:

select*fromuserswherelevel=1

在MSSQLServer7当中的存储过程当中运行没有丝毫的问题,但是到了MSSQLServer20

00当中则会出现运行的错误,原因就是在于在MSSQLServer2000中“level”被当作了关键字

(奇怪的是SQL7当中也同样是关键字,却没问题),所以在SQL2000当中,上面的语句应当改为:

select*fromuserswhere[level]=1

从上面的例子中我们可以看到,在你编写存储过程的时候,最好在有可能和系统关键字的地方使用“[”和“]”将他包

围起来,以避免在移植过程中出现的运行错误问题。

3、在存储过程中使用系统存储过程SP_Executesql的注意事项

我们在编写自己的存储过程的时候,往往在很多的情况下,会使用到系统的存储过程SP_Execute。但是需

要的注意的是,如果你在这个存储过程的参数(一般是一段SQL语句)当中进行了临时Table的操作,那末对于调

用者来说,这个临时Table是不可见的,也就是说你无法通过临时Table来在调用者和被调用者之间传递值。解

决的方法是使用全局临时Table,也就是“##”开头的Table。

4、在存储过程中使用临时Table和游标的注意事项

如果我们的商业逻辑比较复杂,在存储过程当中,就需要一些媒介作为中转台,这时候临时表就发挥了作用,但是请

务必记得在使用完之后,即使删除使用到的临时Table。

而在存储过程当中想要依次遍历一个记录集的唯一方法就是使用系统游标,同样要注意的是,在使用完成之后及时关

闭和销毁游标对象释放他用到的资源。并且不在万不得已的情况下,不要随意使用游标,因为他会占用较多的系统资源,

尤其是对于大并发量的情况下,很容易使得系统资源耗尽而崩溃。

使用临时Table和游标各有利弊,在使用的过程中要适当的利用即可!

5、在存储过程中调用外部的ActiveXDLL程序

有些特殊的情况下,我们可能会需要调用外部的ActiveXDLL程序,这个时候就需要使用到系统的存储过

程sp_OACreate以及其他的相关系统存储过程,都是以sp_OA开头的存储过程,可以自由的在自己的存储

过程当中调用ActiveXDLL的各种方法和属性。比如下面的例子:

DECLARE@objectint

DECLARE@hrint

DECLARE@propertyvarchar(255)

DECLARE@returnvarchar(255)

DECLARE@srcvarchar(255),@descvarchar(255)--建立一个对象(SQLDMO.SQLServer).

EXEC@hr=sp_OACreate'SQLDMO.SQLServer',@object

OUT

IF@hr<>0

BEGIN

EXECsp_OAGetErrorInfo@object,@srcOUT,@desc

OUT

e=@sr

c,Description=@desc

RETURN

END

--设置对象的属性.

EXEC@hr=sp_OASetProperty@object,'HostName','G

izmo'

IF@hr<>0

BEGIN

EXECsp_OAGetErrorInfo@object,@srcOUT,@desc

OUT

SELECThr=convert(varbinary(4),@hr),Source=@sr

c,Description=@desc

RETURN

END

--通过OUTPUT参数获取对象的属性值.

EXEC@hr=sp_OAGetProperty@object,'HostName',@p

ropertyOUT

IF@hr<>0

BEGIN

EXECsp_OAGetErrorInfo@object,@srcOUT,@desc

OUT

e=@sr

c,Description=@desc

RETURN

END

PRINT@property

--调用对象的方法

EXEC@hr=sp_OAMethod@object,'Connect',NULL,'m

y_server','my_login','my_password'

IF@hr<>0

BEGIN

EXECsp_OAGetErrorInfo@object,@srcOUT,@desc

OUT

SELECThr=convert(varbinary(4),@hr),Source=@sr

c,Description=@desc

RETURN

END

--销毁已经创建的ActiveX对象

EXEC@hr=sp_OADestroy@object

IF@hr<>0

BEGIN

EXECsp_OAGetErrorInfo@object,@srcOUT,@desc

OUT

e=@sr

c,Description=@desc

RETURN

END

6、在存储过程中使用数据库事务处理

在很多的情况下,我们在存储过程中都会遇到需要同时操作多个表的情况,这时候就需要避免在操作的过程中由于以

外而造成的数据的不一致性。这时候就需要将操作多个表的操作放入到事务中进行处理。

但是需要注意的是,不能在事务中使用return语句强行退出,这样会引发事务的非正常错误,不能保证数据的一致

性。

并且,一旦将多个处理放入事务当中,系统的处理速度会有所降低,所以应当将频繁操作的多个可分割的处理过程放

入到多个存储过程当中,这样会大大提高系统的响应速度,但是前提是不违背数据的一致性。

看完了上面的这些编写SQL Server存储过程当中的技巧,相信对您或多或少会有些帮助,也希望通过上面的一些经验

总结,可以使得您在应用SQL Server存储过程的时候,有意识的可以避免一些弯路。

第9章 存储过程与存储函数

第9章存储过程与存储函数 一、选择题 1.MySQL中存储过程的建立以关键字()开始,后面仅跟存储过程的名称和参数。A.CREATE FUNCTION B.CREATE TRIGGER C.CREATE PROCEDURE D.CREATE VIEW 2.下列关于存储过程名描述错误的是()。 A.MySQL的存储过程名称不区分大小写。 B.MySQL的存储过程名称区分大小写。 C.存储过程名不能与MySQL数据库中的内置函数重名。 D.存储过程的参数名不要跟字段名一样。 3.下面声明变量正确的是()。 A.DECLARE x char(10) DEFAULT 'outer ' B.DECLARE x char DEFAULT 'outer ' C.DECLARE x char(10) DEFAULT outer D.DECLARE x DEFAULT 'outer ' 4.从tb_sutdent表中将名称为mrsoft的用户赋值给host,以下SQL语句正确的是()。A.SELECT host INTO name FROM tb_sutdent WHERE name ='mrsoft'; B.SELECT name INTO host FROM tb_sutdent WHERE name= 'LeonSK '; C.SELECT name INTO host FROM tb_sutdent WHERE name='mrsoft'; D.SELECT name INTO host FROM tb_sutdent WHERE name=‘mrsoft’; 5.光标的一般使用步骤,以下正确的是()。 A.声明光标使用光标打开光标关闭光标 B.打开光标声明光标使用光标关闭光标 C.声明光标打开光标选择光标关闭光标 D.声明光标打开光标使用光标关闭光标 6.下列控制流程语句中,MySQL存储过程不支持()。 A.WHILE B.FOR C.LOOP D.REPEAT 25

oracle自定义函数和存储过程

oracle自定义函数和存储过程 oracle自定义函数和存储过程(转)2008-07-23 10:43--过程(PROCEDURE)--------------------------------------------------// --创建表 CREATE TABLE user_info ( id VARCHAR2(4), name VARCHAR2(15), pwd VARCHAR2(15), address VARCHAR2(30) ); --插入数据 INSERT INTO user_info VALUES('u001','zhao','zhao','shanghai'); --如要经常执行插入,Oracle每次都要进行编译,并判断语法正确性,因此执行速度可想而知, --所以我们要创建一个过程来实现 CREATE OR REPLACE PROCEDURE AddNewUser ( n_id user_info.id%TYPE, n_name user_https://www.sodocs.net/doc/f412429749.html,%TYPE, n_pwd user_info.pwd%TYPE, n_address user_info.address%TYPE ) AS BEGIN --向表中插入数据 INSERT INTO user_info(id,name,pwd,address) VALUES(n_id,n_name,n_pwd,n_address); END AddNewUser; / --下面我们利用PL/SQL匿名块调用该过程 DECLARE --描述新用户的变量 v_id user_info.id%TYPE := 'u002'; v_name user_https://www.sodocs.net/doc/f412429749.html,%TYPE := 'wish'; v_pwd user_info.pwd%TYPE := 'history'; v_add user_info.address%TYPE := 'shanghai'; BEGIN --调用过程,添加wish用户到数据库

第10章 存储过程、函数和包

第10章存储过程、函数和包 存储过程(PROCEDURE)、函数(FUNCTION)和包(PAKAGE)是以编译的形式存储在数据库中的数据库的对象,并成为数据库的一部分,可作为数据库的对象通过名字被调用和访问。 存储过程通常是实现一定功能的模块;函数通常用于计算,并返回计算结果;包分为包头和包体;用于捆绑存放相关的存储过程和函数,起到对模块归类打包的作用。 存储过程、函数和包是数据库应用程序开发的重要方法,三者既有区别,也有联系。 ?存储过程和存储函数。 ?过程的参数和调用。 ?包和包的应用。 10.1 存储过程和函数 存储过程和函数也是一种PL/SQL块,是存入数据库的PL/SQL块。但存储过程和函数不同于已经介绍过的PL/SQL程序,我们通常把PL/SQL程序称为无名块,而存储过程和函数是以命名的方式存储于数据库中的。 10.1.1 认识存储过程和函数 和PL/SQL程序相比,存储过程有很多优点,具体归纳如下: ·存储过程和函数以命名的数据库对象形式存储于数据库当中。存储在数据库中的优点是很明显的,因为代码不保存在本地,用户可以在任何客户机上登录到数据库,并调用或修改代码。 ·存储过程和函数可由数据库提供安全保证,要想使用存储过程和函数,需要有存储过程和函数的所有者的授权,只有被授权的用户或创建者本身才能执行存储过程或调用函数。 ·存储过程和函数的信息是写入数据字典的,所以存储过程可以看作是一个公用模块,用户编写的PL/SQL程序或其他存储过程都可以调用它(但存储过程和函数不能调用PL/SQL 程序)。一个重复使用的功能,可以设计成为存储过程,比如:显示一张工资统计表,可以设计成为存储过程;一个经常调用的计算,可以设计成为存储函数;根据雇员编号返回雇员的姓名,可以设计成存储函数。 ·像其他高级语言的过程和函数一样,可以传递参数给存储过程或函数,参数的传递也有多种方式。存储过程可以有返回值,也可以没有返回值,存储过程的返回值必须通过参数带回;函数有一定的数据类型,像其他的标准函数一样,我们可以通过对函数名的调用返回函数值。 存储过程和函数需要进行编译,以排除语法错误,只有编译通过才能调用。

存储过程和函数的区别

存储过程与函数的区别 存储过程: 存储过程可以使得对数据库的管理、以及显示关于数据库及其用户信息的工作容易得多。存储过程是SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理。存储过程存储在数据库内,可由应用程序通过一个调用执行,而且允许用户声明变量、有条件执行以及其它强大的编程功能。 存储过程可包含程序流、逻辑以及对数据库的查询。它们可以接受参数、输出参数、返回单个或多个结果集以及返回值。 可以出于任何使用SQL 语句的目的来使用存储过程,它具有以下优点: 1、可以在单个存储过程中执行一系列SQL 语句。 2、可以从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句。 3、存储过程在创建时即在服务器上进行编译,所以执行起来比单个SQL 语句快。 用户定义函数: Microsoft SQL Server 2000 允许创建用户定义函数。与任何函数一样,用户定义函数是可返回值的例程。根据所返回值的类型,每个用户定义函数可分成以下三个类别: 1、返回可更新数据表的函数 如果用户定义函数包含单个Select 语句且该语句可更新,则该函数返回的表格格式结果也可以更新。 2、返回不可更新数据表的函数 如果用户定义函数包含不止一个Select 语句,或包含一个不可更新的Select 语句,则该函数返回的表格格式结果也不可更新。 3、返回标量值的函数 用户定义函数可以返回标量值。 存储过程 功能强大,限制少 不能直接引用返回值 用select语句返回记录集 自定义函数 诸多限制,有许多语句不能使用,许多功能不能实现 可以直接引用返回值 用表变量返回记录集

触发器、存储过程和函数三者有何区别 四

触发器、存储过程和函数三者有何区别四 什么时候用存储过程?存储过程就是程序,它是经过语法检查和编译的SQL语句,所以运行特别快。 触发器是特殊的存储过程,存储过程需要程序调用,而触发器会自动执行;你所说的函数是自定义函数吧,函数是根据输入产生输出,自定义只不过输入输出的关系由用户来定义。在什么时候用触发器?要求系统根据某些操作自动完成相关任务,比如,根据买掉的产品的输入数量自动扣除该产品的库存量。什么时候用存储过程?存储过程就是程序,它是经过语法检查和编译的SQL语句,所以运行特别快。 存储过程和用户自定义函数具体的区别 先看定义: 存储过程 存储过程可以使得对数据库的管理、以及显示关于数据库及其用户信息的工作容易得多。存储过程是SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理。存储过程存储在数据库内,可由应用程序通过一个调用执行,而且允许用户声明变量、有条件执行以及其它强大的编程功能。 存储过程可包含程序流、逻辑以及对数据库的查询。它们可以接受参数、输出参数、返回单个或多个结果集以及返回值。 可以出于任何使用SQL 语句的目的来使用存储过程,它具有以下优点: ·可以在单个存储过程中执行一系列SQL 语句。 ·可以从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句。·存储过程在创建时即在服务器上进行编译,所以执行起来比单个SQL 语句快。用户定义函数 函数是由一个或多个Transact-SQL 语句组成的子程序,可用于封装代码以便重新使用。Microsoft? SQL Server? 2000 并不将用户限制在定义为Transact-SQL 语言一部分的内置函数上,而是允许用户创建自己的用户定义函数。 可使用CREATE FUNCTION 语句创建、使用ALTER FUNCTION 语句修改、以及使用DROP FUNCTION 语句除去用户定义函数。每个完全合法的用户定义函数名(database_name.owner_name.function_name) 必须唯一。 必须被授予CREATE FUNCTION 权限才能创建、修改或除去用户定义函数。不是所有者的用户在Transact-SQL 语句中使用某个函数之前,必须先给此用户授予该函数的适当权限。若要创建或更改在CHECK 约束、DEFAULT 子句或计算列定义中引用用户定义函数的表,还必须具有函数的REFERENCES 权限。 在函数中,区别处理导致删除语句并且继续在诸如触发器或存储过程等模式中的下一语句的Transact-SQL 错误。在函数中,上述错误会导致停止执行函数。接下来该操作导致停止唤醒调用该函数的语句。 用户定义函数的类型

实验14 存储过程与函数

实验十四存储过程与函数 【实验目的与要求】 1.熟练掌握存储过程的编写。 2.熟练掌握函数的编写与使用。 【实验内容与步骤】 14.1.基础知识 存储过程(Stored Procedure)和函数是一组编译好存储在服务器上的完成特定功能T-SQL代码,是某数据库的对象。客户端应用程序可以通过指定存储过程或函数的名字并给出参数(如果该存储过程带有参数)来执行存储过程。 14.2.创建用户存储过程 1. 使用存储过程模板创建存储过程 在【对象资源管理器】窗口中,展开“数据库”节点,再展开所选择的具体数据库节点,再展开选择“可编程性”节点,右击“存储过程”,选择“新建存储过程”命令,如图所示: 在右侧查询编辑器中出现存储过程的模板,可以在此基础上编辑存储过程,单击“执行”按钮,即可创建该存储过程。

实验14-1:创建一个简单的存储过程,实现从CP表中读取Mp3产品相关信息USE CPXS GO CREATE PROCEDURE get_mp3 --此为无参存储过程 AS SELECT产品编号,产品名称,价格,库存量 FROM CP WHERE产品名称='mp3' 实验14-2:执行存储过程 执行存储过程可用下列方法之一: (1)使用存储过程名字如:get_mp3 (2) 使用Exec命令:如:EXEC get_mp3 执行上面创建的存储过程,并给出执行结果:

2. 使用T-SQL语句创建存储过程 在查询分析器里使用T-SQL可直接创建存储过程格式: CREATE PROC 过程名 @形参名类型 @变参名类型OUTPUT AS SQL语句 实验14-3:创建一个多表查询的存储过程。 问题:查询在2009年9月18日有销售的产品名称(1)请给出相应的代码 create proc get_cp as select产品名称 from cp,cpxsb where销售日期='2009-9-18' (2)执行存储过程,并给出执行结果:

实验11 存储过程和用户自定义函数_图

实验11 存储过程和用户自定义函数 实验目的 1.掌握通过企业管理器创建、修改、删除存储过程和用户自定义函数的方法 2.学会编写存储过程和用户自定义函数 3.掌握存储过程的执行方法 4.学会编写、调用三类用户自定义函数 实验准备 1.学习存储过程和用户自定义函数相关知识。 2.已掌握常程序控制流语句。 3.熟练使用T-SQL完成数据查询和程序设计。 4.还原studentdb数据库 实验内容和步骤 1.打开企业管理器,展开studentdb子目录,选中“存储过程”,单击鼠标右键,弹出 快捷菜单,选择【新建存储过程(S)…】,打开新建存储过程窗口,如图11- 1。 图11- 1 新建存储过程

2.新建并执行存储过程“字母打印”。 (1)在新建存储过程窗口输入以下代码。 CREATE PROCEDURE 字母打印AS 注解:该存储过程是将26个小写英文字母按a~z的顺序输出,其中ascii()函 数——返回字符对应ASCII码,char()函数——把ASCII码转换成对应字符。 (2)输入完成后,单击【检查语法】按钮,确认输入内容正确后,单击【确认】按 钮完成存储过程的创建。 (3)打开查询分析器,输入: exec 字母打印 (4)执行,查看运行结果。 3.修改存储过程“字母打印”并执行。 (1)在企业管理器存储过程列表窗格中,选中存储过程“字母打印”,弹出快捷菜 单,选择【属性(R)】,或直接双击该存储过程,打开属性窗口,如图11- 2。

图11- 2 存储过程“字母打印”属性窗口 (2)修改代码内容,将“print char(ascii('a')+@count)”改为“print char(ascii('A')+@count)”。 (3)单击【确认】按钮,完成存储过程的修改。 (4)重新在查询分析器执行该存储过程,查看运行结果。 4.新建并执行带输入参数的存储过程。 (1)在企业管理器中新建存储过程“成绩查询”,代码如下: (2)在查询分析器窗口中,选择studentdb数据库。要求:通过存储过程“成绩查 询”查看学号为“2007224117”的成绩。 ●方法一:输入exec 成绩查询‘2007224117’,并执行。 ●方法二:输入 执行,查看该同学的成绩。 注:以上是执行含输入参数存储过程的常用方法,参数可以直接通过值传递, 也可以通过变量传递。 5.练习:请新建存储过程“学生信息”,输入参数仍为学号,返回学号对应的“学生” 表信息,并通过该存储过程查看学号为“2007224117”的个人信息。 6.新建带返回参数的存储过程并执行。 (1)在企业管理器中新建存储过程“学生平均成绩”,代码如下:

存储过程和函数的区别

存储过程和函数的区别 存储过程是用户定义的一系列sql语句的集合,涉及特定表或其它对象的任务,用户可以调用存储过程,而函数通常是数据库已定义的方法,它接收参数并返回某种类型的值并且不涉及特定用户表。 . l 视图的优点?建立视图的基本语法结构? 视图的优点: 1. 视图对于数据库的重构造提供了一定程度的逻辑独立性。数据的逻辑独立性是指数据库重构造时,如数据库扩大(增加了新字段,新关系等),用户和用户程序不会受影响。 2. 简化了用户观点。视图的机制使用户把注意力集中在他所关心的数据上。若这些数据不是直接来自基本表,则可以定义视图,从而使用户眼中的数据结构简单而直接了当,并可大大简化用户的数据查询操作,特别是把若干表连接在一起的视图,把从表到表所需要的连接操作向用户隐蔽了起来。 3. 视图机制使不同的用户能以不同的方式看待同一数据。 4. 视图机制对机密数据提供了自动的安全保护功能。可以把机密数据从公共的数据视图(基本表)中分离出去,即针对不同用户定义不同的视图,在用户视图中不包括机密数据的字段。这样,这类数据便不能经由视图被用户存取,从而自动地提供了对机密数据的保护。 视图的基本语法结构: CREATE VIEW view_name [(column ][,...n])] AS select_statement 其中view_name为要建立的视图的名称,而AS子句后面的就是建立视图的查询语句。而此语句有以下限制:不能包含ORDER BY、COMPUTE和COMPUTE BY等子句;不能包含INTO 关键字;不能涉及临时表。 . l 事务是什么? 事务是作为一个逻辑单元执行的一系列操作,一个逻辑工作单元必须有四个属性,称为ACID (原子性、一致性、隔离性和持久性)属性,只有这样才能成为一个事务: 1、原子性:事务必须是原子工作单元;对于其数据修改,要么全都执行,要么全都不执行。 2、一致性:事务在完成时,必须使所有的数据都保持一致状态。在相关数据库中,所有规

存储过程和函数

存储过程和函数 1:创建一个可以向dept表中插入一行的过程 CREATE OR REPLACE PROCEDURE pro_c AS BEGIN INSERT INTO emp V ALUES(8902,'FORD','ANAL YST',7566,to_date('1981-12-3','yyyy-MM-dd'),3000.00,null,20); END; 2:创建一个过程,传入雇员名,返回该雇员的薪水(薪金+佣金) CREATE OR REPLACE PROCEDURE pro_2(names V ARCHAR2,sals OUT NUMBER ) AS BEGIN SELECT sal+nvl(comm,0) INTO sals FROM emp WHERE ename=names; END; --调用存储过程 DECLARE sa NUMBER; BEGIN pro_2('SCOTT',sa); dbms_output.put_line('薪水为:'||pro_2('SCOTT',sa)); END; 3:创建一个过程,传入雇员号,和薪水及增长比例(10%=0.1)。其中薪水为in out参数!更新薪水为新薪水用一个PL/SQL程序块来调用此过程,其传入到过程中的参数都是用户输入得到的 CREATE OR REPLACE PROCEDURE pro_3(num NUMBER,sal IN OUT NUMBER,increase NUMBER) AS BEGIN UPDATE emp SET sal=sal*(1+increase) WHERE empno=num; COMMIT; SELECT sal INTO sal FROM emp WHERE empno=num; END; --调用存储过程 DECLARE num NUMBER; incre NUMBER; sal NUMBER; BEGIN

第11章MySQL存储过程与函数

数据库系统原理及MySQL应用教程(第2版) 课后习题参考答案 第11章MySQL存储过程与函数 1、存储过程和存储函数是在数据库中定义一些被用户定义的SQL语句集合。 二者存在以下几个区别: 1)存储过程实现的功能要复杂一点,而函数实现的功能针对性比较强。 2)存储过程可以返回参数,而函数只能返回值或者表对象。 3)存储过程可以使用非确定函数,不允许在用户定义函数主体中内置非确定函数。 4)存储过程一般是作为一个独立的部分来执行,而函数可以作为查询语句的一个部分来调用。 2、创建一个存储过程,根据学生的学号查询学生的姓名 create PROCEDURE getnamebysno(in xh char(10),out name char(20)) BEGIN select sname into name from student where sno=xh; 调用该存储过程:call getnamebysno(‘1101’); 创建一个名为numstu的存储函数,查询学生的人数 Create function numstu() Returns integer Begin Return(select count(*) from student); 调用:select numstu() 3、存储过程的优点: ◆存储过程增强了SQL语言的功能和灵活性 ◆存储过程能实现较快的执行速度。 ◆存储过程允许标准组件是编程。

◆存储过程能过减少网络流量。 ◆存储过程可被作为一种安全机制来充分利用。 4、查看存储函数状态方法: ●通过show status语句 ●如果要查看存储过程或函数的详细信息,要使用show create语句 5、游标是一个被SELECT语句检索出来的结果集。在存储了游标后,应用程序或用户就可以根据需要滚动或浏览其中的数据。 6、游标(cursor)具有以下特性: ●只读的,不能更新的 ●不滚动的 ●不敏感的,不敏感意为服务器可以活不可以复制它的结果表 (1)游标的声明:语法格式:declare cursorname cursor for select _ statement (2)打开游标:Open cursor_ name (3)读取游标:fetch cursor_name into var_ name [,var_name] …(4) 关闭游标:close cursorname 7、CREATE PROCEDURE sp_update email(IN USer_name VARCHAR(50),IN e_mail VARCHAR(50)) UPDATE content SET email=e_mail WHERE username=user_name; 8、A 9 D 10 D 11 B 12 (1) create proceduce p1() select dno,count(*) from emp group by dno; (2) create proceduce p2(in gy char(10)) select * from emp where dno=gy; (3) create proceduce p3() select count(*) as 人数from emp where sex=’女’; (4) create proceduce p4(in gy char(10)) select avg(empage) from emp where dno=gy; call p4(‘11’);

MySQL实验报告5(存储过程与函数)(1)(1)

四、实验内容及程序代码 1.sch数据表的表结构如表7.1所示,sch表的数据如表7.2。 表7.1 sch 表结构 字段名数据类型主键外键非空唯一自增 id INT(10) 是否是是否 name V ARCHAR(50) 否否是否否 class V ARCHAR(50) 否否是否否 表7.2 sch 表的内容 id name class 1 李明C1 2 小梅C2 1)建表sch并插入数据。 2)创建一个存储函数,用来统计表sch中的记录数。 delimiter $$ create PROCEDURE count_sch5(out size int) BEGIN select count(*) into size from sch; END $$ delimiter; 3)创建一个存储过程,通过调用存储函数的方法来获取表sch中的记录数和sch表中id 的和。 delimiter $$

create PROCEDURE count_sch2(out s_a int,out s_id int) BEGIN select count(*) into s_a from sch; select sum(id) as s_id from sch; END $$ delimiter; 2.创建一存储过程insert_student_condition_user,利用自定义错误触发条件定义,当插入学生的性别不是“男”或“女”时结束存储过程,并提示“学生性别不正确”。 表7.3 student表结构 字段名数据类型主键外键非空唯一自增 sno Char(10) 是否是是否 sname VARCHAR(20) 否否是否否 ssex CHAR(2) 否否是否否 Sage smallint 否否是否否 Sdept VARCHAR(30) 否否是否否 enterdate datetime 否否是否否 delimiter $$ create PROCEDURE insert_student_condition_user(in sno int,in sname VARCHAR(20), in ssex varchar(2),in sage int,in sdept varchar(30)) BEGIN DECLARE continue handler for sqlstate '42S02' select '学生性别不正确'; if ssex='男' or ssex='女' THEN insert into student values(sno,sname,ssex,sage,sdept);

存储过程和函数及包和包体

create or replace procedure jiujiu is begin for i in 1..9 loop for j in 1..i loop dbms_output.put(j || '*' || i || '=' || i*j || ' '); end loop; dbms_output.new_line(); end loop; end; begin jiujiu(); end; execute jiujiu(); ---------------------------------------------- drop procedure jiujiu;//删除存储过程 --------------------------------------------- CREATE OR REPLACE PROCEDURE getEname(eno emp.empno%TYPE) IS v_ename emp.ename%TYPE; BEGIN SELECT ename INTO v_ename FROM emp WHERE empno=eno; dbms_output.put_line(v_ename); EXCEPTION WHEN no_data_found THEN dbms_output.put_line('您输入的员工编号不正确,请检查后重新输入!'); END; declare v_pno emp.empno%type; begin v_pno:=&员工编号; getEname(v_pno); end; execute getEname(7788); ----------------------------------------------------

实验10: 存储过程和存储函数

实验十存储过程和函数 一、实验目的: 1、熟悉Navicat Premium9工具的使用; 2、掌握MySQL中存储过程和函数的应用 二、实验内容: 1、打开第7周,实验六已经创建好的数据库表。创建一个存储函数用来统计表employee中的记录数。 2、创建一个存储过程,通过调用存储函数的方式来获取表employee 中的记录数和employee表中所有e_salary之平均值。 要求:必须使用变量、光标和流程控制,在存储过程中调用存储函数。提示:先创建一个光标来获取每条记录的e_salary,使用循环语句来实现相加,再除以之前定义的存储函数的统计值。 e_no e_name e_sex e_job e_salary dept_no hireDate 1001 smith 男教师5000 80001 2008-08-08 1002 allen 男辅导员4000 80001 2011-04-15 1003 ward 男教师4200 80001 2012-03-01 1004 jones 女教师4200 80002 2012-03-01 1005 martin 女教务员3200 80002 2009-07-01

1006 blake 男教师8000 80002 2003-02-01 1007 clark 女教师6300 80003 2004-08-01 1008 scott 女辅导员5500 80003 2006-08-01 1009 king 男教师4800 80004 2010-12-24 1010 turner 男辅导员5700 80004 2004-08-01 1011 adams 男辅导员3600 80004 2011-04-15 1012 james 女教师4600 80004 2007-09-01

7存储过程和函数课后习题

习题 一、选择题 1.如果当前日期为2003/9/17,下面可以返回17的函数是()。 A.DATEPART(8,9,GETDATE()) B.DATEPART(day,GETDATE()) C.DATEPART(date) D.DATEPART(date,GETDATE()) 2.下列()是对存储过程的描述 A.定义了一个有相关列和行的集合 B.当用户修改数据时,一种特殊形式的存储过程被自动执行 C.SQL语句的预编译集合 D.它根据一或多列的值,提供对数据库表的行的快速访问 3.对于下面的存储过程: CREATE PROCEDURE Myp1 @P Int As select Studentname,Age from Strdents where Age==@p 如果在students表中查找年龄18岁的学生,正确调用存储过程的是() A.exec Myp1 @p=’18’ B.exec Myp1 @p=18 C.exec Myp1 p=’18’ D.exec Myp1 p=18 4.下面哪一个关键字不是Transac-SQL的函数?() A.DAY() B.YEAR() C.MONTH() D.SECOND() 5.下面哪一个函数用于判断两个日期相隔的时间差?() A.DATEADD() B.DATEDIFF () C.DATENAME D.GETDATE 6.下列函数中,返回值数据类型为int 的是()。 A.LEFT B.LEN C.LTRIM D.SUNSTRING 7.SELECT CHARINDEX ('V',SUBSTRING('SQL SERVER 2008',5,6))得到的结果是()A.4 B.6 C.V D.S 8.SELECT LEFT(REPLACE('abcdefghicde','cde','xxx'),4) 得到的结果是()A.abcd

相关主题