时间:2021-02-10 14:49:23 | 栏目:MsSql | 点击:次
为什么要使用存储过程?以下是存储过程技术的几大主要优点:
结构
存储过程的结构跟其他编程语言非常相似。存储过程接受输入参数形式的数据。这些输入参数在执行系列语句的时候被运用并生成结果。结果在通过使用记录集、输出参数和返回代码返回。听起来似乎很复杂,实际上存储程序非常简单。
实例
假设我们有如下名为Inventory的表格,表格里的数据需要实时更新,仓库经理会不停地检查仓库里的货存数量和可供发货的货存数量。以前,每一个地区的仓库经理都会进行如下查询:
以下是引用片段: SELECT Product, Quantity FROM Inventory WHERE Warehouse = 'FL' |
这样的查询使SQL Server性能效率非常低下。每次仓库经理执行该查询,数据库服务器都不得不重新对其进行编译然后重新开始执行。这样的查询还要求仓库经理具备SQL方面的知识,并且拥有访问表格数据的权限。
我们可以通过使用存储过程来简化这个查询过程。首先创建一个名为 sp_GetInventory的过程,能够获取一个已有仓库的货存水平。下面是创建该程序的SQL代码:
以下是引用片段: CREATE PROCEDURE sp_GetInventory @location varchar(10) AS SELECT Product, Quantity FROM Inventory WHERE Warehouse = @location |
A地区的仓库经理可以执行下面的命令来获得货存水平:
以下是引用片段: EXECUTE sp_GetInventory 'FL' |
B地区的仓库经理可以使用同样的存储过程来访问该地区的货存信息。
以下是引用片段: EXECUTE sp_GetInventory 'NY' |
当然,这只是一个很简单的例子,但是可以看出来存储过程的好处。仓库经理不一定要懂得SQL或者存储过程内在的工作原理。从性能的角度看的话,存储过程无疑大大地提高了工作的效率。SQL Server只需创建执行计划一次,然后就可以重复使用存储过程,只需要在每次执行时输入适当的参数就可以了。
ID
|
Product
|
Warehouse
|
Quantity
|
142
|
Green beans
|
NY
|
100
|
214
|
Peas
|
FL
|
200
|
825
|
Corn
|
NY
|
140
|
512
|
Lima beans
|
NY
|
180
|
491
|
Tomatoes
|
FL
|
80
|
379
|
Watermelon
|
FL
|
85
|