什么是数据库存储过程?

什么是数据库存储过程?,第1张

SQL的调用可以分为函数存储过程

个人理解,其实函数和存储过程是相似的,至少在引用的时候跟函数很是一样。或者干脆把存储过程理解为另一种函数,另一种经过优化的函数。它的优点在于,存储过程在被编译后会被直接保存在数据库中,成为数据库的一部分,以后就可以反复调用,运行速度快,效率高,这些是函数做不到的。

存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象。

种类

1系统存储过程

以sp_开头,用来进行系统的各项设定.取得信息.相关管理工作。

2本地存储过程

用户创建的存储过程是由用户创建并完成某一特定功能的存储过程,事实上一般所说的存储过程就是指本地存储过程。

3临时存储过程

分为两种存储过程:

一是本地临时存储过程,以井字号(#)作为其名称的第一个字符,则该存储过程将成为一个存放在tempdb数据库中的本地临时存储过程,且只有创建它的用户才能执行它

二是全局临时存储过程,以两个井字号(##)号开始,则该存储过程将成为一个存储在tempdb数据库中的全局临时存储过程,全局临时存储过程一旦创建,以后连接到服务器的任意用户都可以执行它,而且不需要特定的权限。

4远程存储过程

在SQL Server2005中,远程存储过程(Remote Stored Procedures)是位于远程服务器上的存储过程,通常可以使用分布式查询和EXECUTE命令执行一个远程存储过程。

5扩展存储过程

扩展存储过程(Extended Stored Procedures)是用户可以使用外部程序语言编写的存储过程,而且扩展存储过程的名称通常以xp_开头。

存储过程,实际就是一段写在数据库中的代码。。

由于此段数据库 *** 作代码由服务器完成,而客户端只是进行简单的参数提交,所以,可以有效的利用服务器的强劲而减小对客户机的负合。

如:你想插入一条数据到数据库。

虽然你的要求是,先检查表里面是否己存在该项。

如果不存在就Insert,如果存在就UPDATE。

这个时候,你就可以把这个判断用存储过程来写。

你的程序只要提示你想要保存到数据库里面的东西即可。

下面就是一个简单的存储过程。

CREATE

PROCEDURE

[insert_A_Employees]

(@fWorkNo

[int],

@fWorkName

[char](10),

@fDeptName

[varchar](20),

@fGroupName

[varchar](20),

@fRecordDate

[datetime])

AS

declare

@iCount

int

select

@iCount

=

count(*)

from

A_EMPLOYEES

where

@fWorkNo

=

fWORKNO

--统计该工号在数据库的数量赋值给

@iCount

if

@iCount

=

0

--如果数据库中不存在该工号

begin

INSERT

INTO

[CLKQ].[dbo].[A_Employees]

--则插入数据

(

[fWorkNo],

[fWorkName],

[fDeptName],

[fGroupName],

[fRecordDate])

VALUES

(

@fWorkNo,

@fWorkName,

@fDeptName,

@fGroupName,

@fRecordDate)

return

1

--返回一个标识

end

else

begin

--否则则更新数据

update

[CLKQ].[dbo].[A_Employees]

set

[fWorkName]=@fWorkName,

[fDeptName]=@fDeptName,

[fGroupName]=@fGroupName,

[fRecordDate]=@fRecordDate

where

[fWorkNo]=@fWorkNo

return

0

--返回一个标识

end

GO

此时你只要在客户端程序提供:

@fWorkNo

,

@fWorkName

,

@fDeptName

,

@fGroupName

,

@fRecordDate

这几个值就行了。。

其它处理过程就由服务器方处理了。

以上是以

SQL

数据库为例。。。

ACCESS

等数据库没有此功能。

exec(@sql)内生成的表,只在exec函数内部有效,在exec函数是不可见的

局部临时表只局限于创建进程以及创建进程的子进程

那么将存储过程看作是一个进程1,而exec(@sql)则是另一个进程2

根据我上面说的,#temp只会作用于创建它的进程2中

那么要想使#temp贯穿整个存储过程,则需要在存储过程中先用create table #temp来创建这个临时表,这样这个临时表的创建者就升级成了进程1,其他的无论进程2、进程3都是进程1的子进程,这样就都能引用到#temp,此时进程2中的语句就要改写成insert into而不是select into了

不过这个前提是你已知晓表结构,可以固定的创建临时表

否则你只能用exec(@sql)的形式将整个存储过程体都以拼接的方式执行

也就是不通过临时表,直接用exec(@sql)将查询结果输出


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/6936496.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-03-30
下一篇2023-03-30

发表评论

登录后才能评论

评论列表(0条)

    保存