SQL Server 存储过程解析
存储过程功能的优点
为什么要使用存储过程?以下是存储过程技术的几大主要优点:
- 预编译执行程序。SQL Server只需要对每一个存储过程进行一次编译,然后就可以重复使用执行计划。这个特点通过重复调用存储程序极大地提高了程序的性能。
- 缩短客户端/服务器之间的信息传输量。如果你的工作环境带宽有限,那么存储过程技术肯定能够满足你,因为它能够把需要传输的长的SQL查询缩短成一行。
- 有效重复使用代码和编程。存储过程可以为多个用户所使用,也可以用于多个客户程序。这样可以减少程序开发周期的时间。
- 增强安全性控制。可以允许用户单独执行存储过程,而不给于其访问表格的权限。
结构
存储过程的结构跟其他编程语言非常相似。存储过程接受输入参数形式的数据。这些输入参数在执行系列语句的时候被运用并生成结果。结果在通过使用记录集、输出参数和返回代码返回。听起来似乎很复杂,实际上存储程序非常简单。
实例
假设我们有如下名为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 |
相关推荐
-
基于Sql Server通用分页存储过程的解决方法
sql server2000分页方式很多,效率吗 当到达10万级以上就有些吃力了,这里暂时不例出来了 sql server2005以上就有了row_number 也是一大进步,详情如下参考 复制代码 代码如下: Sql Server2005通用分页存储过程 CREATE PROCEDURE [dbo].[Common_GetPagedList](@TableName nvarchar(100), --表名@ColumnNames nvarchar(1000) = '*', --字段名集合(全部
-
SQL Server存储过程的基础说明
可以创建一个过程供永久使用,或在一个会话中临时使用(局部临时过程),或在所有会话中临时使用(全局临时过程). 也可以创建在Microsoft SQL Server启动时自动运行的存储过程. 语法 CREATE PROC [ EDURE ] procedure_name [ ; number ] [ { @parameter data_type } [ VARYING ] [ = default ] [ OUTPUT ] ] [ ,...n ] [ WITH { RECOMPILE | ENCRY
-
深入sql server 2005 万能分页存储过程的详解
–建立主表临时表CREATE TABLE #temp(rownumber bigint,orderseqno VARCHAR(36),goodsname VARCHAR(50),companyname VARCHAR(100))–建立子表临 时表CREATE TABLE #detail(orderseqno VARCHAR(36),detailid UNIQUEIDENTIFIER,unitprice DECIMAL(12,2),Qty int)–插入主表数据到主表临时表insert into
-
SQL Server常用存储过程及示例
分页: 复制代码 代码如下: /*分页查找数据*/ CREATE PROCEDURE [dbo].[GetRecordSet] @strSql varchar(8000),--查询sql,如select * from [user] @PageIndex int,--查询当页号 @PageSize int--每页显示记录 AS set nocount on declare @p1 int declare @currentPage int set @currentPage = 0 declare @
-
SQL Server 分页查询存储过程代码
复制代码 代码如下: CREATE PROCEDURE [dbo].[up_Pager] @table varchar(2000), --表名 @col varchar(50), --按该列来进行分页 @orderby bit, --排序,0-顺序,1-倒序 @collist varchar(800),--要查询出的字段列表,*表示全部字段 @pagesize int, --每页记录数 @page int, --指定页 @condition varchar(800) --查询条件 AS DECL
-
SQL Server存储过程入门学习
存储过程的定义, 存储过程(Stored Procedure),是一组为了完成特定功能的SQL 语句,集经编译后存储在数据库中,用户通过指定存储过程的名字并给出参数,如果该存储过程带有参数来执行.在SQL Server 的系列版本中,存储过程分为两类:系统提供的存储过程和用户自定义存储过程.系统SP,主要存储master 数据库中,并以sp_为前缀并且系统存储过程主要是从系统表中获取信息,从而为系统管理员管理SQL Server.用户自定义存储过程是由用户创建,并能完成某一特定功能,如:查询用户
-
SQL Server 存储过程解析
存储过程功能的优点 为什么要使用存储过程?以下是存储过程技术的几大主要优点: 预编译执行程序.SQL Server只需要对每一个存储过程进行一次编译,然后就可以重复使用执行计划.这个特点通过重复调用存储程序极大地提高了程序的性能. 缩短客户端/服务器之间的信息传输量.如果你的工作环境带宽有限,那么存储过程技术肯定能够满足你,因为它能够把需要传输的长的SQL查询缩短成一行. 有效重复使用代码和编程.存储过程可以为多个用户所使用,也可以用于多个客户程序.这样可以减少程序开发周期的时间. 增强安全性控
-
SQL Server存储过程中使用表值作为输入参数示例
在2008之前如果我们想要将表作为输入参数传递给SQL Server存储过程使比较困难的,可能需要很多的逻辑处理将这些表数据作为字符串或者XML传入. 在2008中提供了表值参数.使用表值参数,可以不必创建临时表或许多参数,即可向 Transact-SQL 语句或例程(如存储过程或函数)发送多行数据,这样可以省去很多自定义的代码.这样的操作对于存储过程内基于表函数的操作变得非常容易操作. 表值参数是使用用户定义的表类型来声明的.所以使用之前要先定义表类型. /* 创建表类型.*/ CREATE
-
Sql Server 存储过程调用存储过程接收输出参数返回值
创建存储过程: ALTER PROCEDURE [dbo].[GetCustomers] (@rowcount INT OUTPUT) AS SELECT [CustomerID] ,[CompanyName] ,[ContactName] ,[ContactTitle] ,[Address] ,[City] ,[Region] ,[PostalCode] ,[Country] ,[Phone] ,[Fax] FROM [Northwind].[dbo].[Customers] SET @row
-
SQL Server 存储过程遇到“表 ''#TT'' 没有标识属性无法执行 SET 操作”错误
创建临时表,往临时表插入数据的时候报的错误. 一开始提示没有打开主键,后来打开主键就提示上述错误异常. 从网上查找资料没有找到,然后又到群里问各位大牛,一位大牛告诉我是没有设置主键. 我又仔细看看提示,恍然大悟,我就给临时设置了主键. 没有主键之前的代码: CREATE TABLE #TT( CourseId INT , UserId INT, ClassId INT ) INSERT INTO #TT ( CourseId, UserId, ClassId ) SELECT CourseId,
-
SQL Server存储过程中编写事务处理的方法小结
本文实例讲述了SQL Server存储过程中编写事务处理的方法.分享给大家供大家参考,具体如下: SQL Server中数据库事务处理是相当有用的,鉴于很多SQL初学者编写的事务处理代码存往往存在漏洞,本文我们介绍了三种不同的方法,举例说明了如何在存储过程事务处理中编写正确的代码.希望能够对您有所帮助. 在编写SQL Server 事务相关的存储过程代码时,经常看到下面这样的写法: begin tran update statement 1 ... update statement 2 ...
-
SQL Server存储过程在C#中调用的简单实现方法
0. 简介 [定义]:存储过程(Stored Procedure) 是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,它存储在数据库中,一次编译后永久有效,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它. [优缺点]:存储过程优缺点都非常的明显!几乎每一篇讨论存储过程的文字,都是会说其他优点是balabala,缺点是balabala,然而最后作者的结论都是:"我不推荐使用存储过程". 具体的存储过程的优缺点这里就不详述了! 公司旧项目使用存储过程实现业
-
使用SQL SERVER存储过程实现历史数据迁移方式
目录 1.什么是历史数据迁移? 2.历史数据迁移的目的 3.什么时候需要做历史数据迁移? 4.数据迁移的基本思路 6.使用场景特别说明 今天讲下软件开发中最常见的历史数据迁移方式.在讲迁移之前,先简单介绍下几个基本概念. 1.什么是历史数据迁移? 简单直白地说:就是将一些创建时间比较久而且不常用的历史数据,存储到另一个地方(可以是另一个数据,也可以是另一个表),一般历史数据迁移的数据,都是不会更改了的数据,后续只可能需要查询统计而已. 2.历史数据迁移的目的 减少在用数据库的数量,因为数据量越大
-
SQL SERVER存储过程用法详解
目录 一.存储过程的概念 存储过程的优点 二.存储过程的分类 1.系统存储过程 2.临时存储过程 3.用户自定义存储过程 二.存储过程的用法 1.不带参数的存储过程,获取MyStudentInfo表的所有记录 2.创建带输入参数的存储过程 3.创建带默认值的输入参数的存储过程 4.创建带输出参数的存储过程(根据输入的ID返回年级ID) 5.创建带返回值的存储过程 6.创建带变量的存储过程 7.创建带输入输出参数的存储过程 8.创建分页存储过程 分页存储过程2 9.返回多个结果集 10.存储过程中
-
SQL Server 存储过程遇到“表 ''#TT'' 没有标识属性无法执行 SET 操作”错误
创建临时表,往临时表插入数据的时候报的错误. 一开始提示没有打开主键,后来打开主键就提示上述错误异常. 从网上查找资料没有找到,然后又到群里问各位大牛,一位大牛告诉我是没有设置主键. 我又仔细看看提示,恍然大悟,我就给临时设置了主键. 没有主键之前的代码: CREATE TABLE #TT( CourseId INT , UserId INT, ClassId INT ) INSERT INTO #TT ( CourseId, UserId, ClassId ) SELECT CourseId,
-
Sql Server存储过程详解
从存储过程返回数据 - SQL Server | Microsoft 官方文档 存储过程它是真正的脚本,更准确地说,它是批处理(batch),但都不是很确切,它存储与数据库而不是单独的文件中. 存储过程中有输入参数,输出参数以及返回值等. 一.创建存储过程:CREATE PROC 创建存储过程的方法除了他使用AS关键字外,和创建数据库中任何其他对象一样.存储过程的基本语法如下: 在语法中,PROC是PROCEDURE的缩写,两个选项的意思一样.在对存储过程命名完之后,接着是参数列表.参数是可选
随机推荐
- Oracle Database Server 'TNS Listener'远程数据投毒漏洞(CVE-2012-1675)的完美解决方法
- Mysql从5.6.14安全升级至mysql5.6.25的方法
- asp 批量删除选中的多条记录
- 详解Java MyBatis 插入数据库返回主键
- js离开或刷新页面检测(且兼容FF,IE,Chrome)
- Visual Studio 2017 离线安装教程
- Symfony实现行为和模板中取得request参数的方法
- php、java、android、ios通用的3des方法(推荐)
- php+html5实现无刷新图片上传教程
- jQuery实现的简单前端搜索功能示例
- JavaScript 盒模型 尺寸深入理解
- 简单架设SSH+Squid代理服务器的自由上网通道的方法
- Spring SpringMVC在启动完成后执行方法源码解析
- Android ProgressDialog使用总结
- 深入剖析Android的Volley库中的图片加载功能
- Android抽象布局——include、merge 、ViewStub详解
- 软路由还是硬路由 最合适才是好路由
- socket io与vue-cli的结合使用的示例代码
- Android Jni的简单使用详解
- Spring Boot Dubbo 构建分布式服务的方法