数据库中的存储过程是什么

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

存储过程是存储在

.dbc

文件中的

Visual

FoxPro

代码,是专门 *** 作数据库中数据的代码过程。存储过程可以提高数据库的性能,因为在打开一个数据库时,它们便加载到了内存中。

使用存储过程主要是为了创建用户自定义函数,字段级规则和记录级有效性规则将引用这些函数。当把一个用户自定义函数作为存储过程保存在数据库中时,函数的代码保存在

.dbc

文件中,并且在移动数据库时,会自动随数据库移动。使用存储过程能使应用程序更容易管理,因为可以不必在数据库文件之外管理用户自定义函数。

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

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

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

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

如果不存在就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

等数据库没有此功能。


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

原文地址: http://outofmemory.cn/sjk/6758884.html

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

发表评论

登录后才能评论

评论列表(0条)

保存