存储过程其实就是已预编译为可执行过程的一个或多个SQL语句。 通过调用和传递参数即可完成该存储过程的功能。

前面有介绍过存储过程的一些语法,但是没有详细示例,今天我们来一起研究一下存储过程。

提高性能

SQL语句在创建过程时进行分析和编译。 存储过程是预编译的,在首次运行一个存储过程时,查询优化器对其进行分析、优化,并给出最终被存在系统表中的存储计划,这样,在执行过程时便可节省此开销。

2降低网络开销

存储过程调用时只需用提供存储过程名和必要的参数信息,从而可降低网络的流量。

3便于进行代码移植

数据库专业人员可以随时对存储过程进行修改,但对应用程序源代码却毫无影响,从而极大的提高了程序的可移植性。

4更强的安全性

1)系统管理员可以对执行的某一个存储过程进行权限限制,避免非授权用户对数据的访问
2)在通过网络调用过程时,只有对执行过程的调用是可见的。 因此,恶意用户无法看到表和数据库对象名称、嵌入自己的 Transact-SQL 语句或搜索关键数据。
3)使用过程参数有助于避免 SQL 注入攻击。 因为参数输入被视作文字值而非可执行代码,所以,攻击者将命令插入过程内的 Transact-SQL 语句并损害安全性将更为困难。
4)可以对过程进行加密,这有助于对源代码进行模糊处理。

劣势:

1逻辑处理吃力

SQL本身是一种结构化查询语言,但不是面向对象的的,本质上还是过程化的语言,面对复杂的业务逻辑,过程化的处理会很吃力。同时SQL擅长的是数据查询而非业务逻辑的处理,如果如果把业务逻辑全放在存储过程里面,违背了这一原则。

2修改参数复杂

如果需要对输入存储过程的参数进行更改,或者要更改由其返回的数据,则您仍需要更新程序集中的代码以添加参数、更新调用,等等,这时候估计会比较繁琐了。

3开发调试复杂

由于IDE的问题,存储过程的开发调试要比一般程序困难。

4无法应用缓存

虽然有全局临时表之类的方法可以做缓存,但同样加重了数据库的负担。如果缓存并发严重,经常要加锁,那效率实在堪忧。

5不支持群集

数据库服务器无法水平扩展,或者数据库的切割(水平或垂直切割)。数据库切割之后,存储过程并不清楚数据存储在哪个数据库中。

创建不带参数的存储过程

示例:查询订单表中订单总数

--查询存储过程

IF OBJECT_ID (N'PROC_ORDER_COUNT', N'P') IS NOT NULL

DROP procedure PROC_ORDER_COUNT;

GO

CREATE procedure PROC_ORDER_COUNT

AS

SELECT COUNT(OrderID) FROM Orders;

GO

执行上述存储过程:

EXEC PROC_ORDER_COUNT;

2创建带参数的存储过程

示例:根据城市查询订单数量

--查询存储过程,根据城市查询总数

IF OBJECT_ID (N'PROC_ORDER_COUNT', N'P') IS NOT NULL

DROP procedure PROC_ORDER_COUNT;

GO

CREATE procedure PROC_ORDER_COUNT(@city nvarchar(50))

AS

SELECT COUNT(OrderID) FROM Orders WHERE City=@city

GO

执行上述存储过程:

EXEC PROC_ORDER_COUNT  N'GuangZhou';

参数带通配符

--查询订单编号头两位是LJ的订单信息,含通配符

IF OBJECT_ID (N'PROC_ORDER_INFO', N'P') IS NOT NULL

DROP procedure PROC_ORDER_INFO;

GO

CREATE procedure PROC_ORDER_INFO

@OrderID nvarchar(50)='LJ%' --默认值

AS

SELECT OrderID,City,OrderDate,Price FROM Orders

WHERE OrderID like @OrderID;

GO

执行上述存储过程:

EXEC PROC_ORDER_INFO;

EXEC PROC_ORDER_INFO N'LJ%';

EXEC PROC_ORDER_INFO N'%LJ%';

4带输出参数

--根据订单查询的信息,返回订单的城市及单价

IF OBJECT_ID (N'PROC_ORDER_INFO ', N'P') IS NOT NULL

DROP procedure PROC_ORDER_INFO ;

GO

CREATE procedure PROC_ORDER_INFO

@orderid nvarchar(50),     --输入参数

@city nvarchar(20) out, --输出参数

@price  float output        --输入输出参数

AS

SELECT @city=City,@price=Price FROM Orders

WHERE OrderID=@orderid AND Price=@price;

GO

执行上述存储过程:

declare @orderid nvarchar(50),

@city nvarchar(20),

@price  int;

set @orderid= N'LJ0001';

set @price = 35.21;

exec PROC_ORDER_INFO @orderid,@city out, @price output;

select @city, @price;

上面两个在平时工作中遇到的较少,需要的时候知道怎么用即可,1,2个是必须掌握的操作。

新增

--新增订单信息

IF OBJECT_ID (N'PROC_INSERT_ORDER', N'P') IS NOT NULL

DROP procedure PROC_INSERT_ORDER;

GO

CREATE procedure PROC_INSERT_ORDER

@orderid  nvarchar(50),

@city nvarchar(20),

@price float

AS

INSERT INTO Orders(OrderID,City,Price)

VALUES(@orderid,@city,@price)

GO

执行

EXEC PROC_INSERT_ORDER N'LJ0001',N'GuangZhou',35.21;

2修改

--修改订单信息

IF OBJECT_ID (N'PROC_UPDATE_ORDER', N'P') IS NOT NULL

DROP procedure PROC_UPDATE_ORDER;

GO

CREATE procedure PROC_UPDATE_ORDER

@orderid  nvarchar(50),

@city nvarchar(20),

@price float

AS

UPDATE Orders SET OrderID=@orderid,City=@city,Price=@price;

GO

执行

EXEC PROC_UPDATE_ORDER N'LJ0001',N'ShangHai',37.21;

3删除

--修改订单信息

IF OBJECT_ID (N'PROC_DELETE_ORDER', N'P') IS NOT NULL

DROP procedure PROC_DELETE_ORDER;

GO

CREATE procedure PROC_DELETE_ORDER

@orderid  nvarchar(50),

AS

DELETE  FROM Orders WHERE OrderID=@orderid;

GO

执行

EXEC PROC_DELETE_ORDER N'LJ0001';

重复编译存储过程

--重复编译

IF OBJECT_ID (N'PROC_ORDER_WITH_RECOMPILE', N'P') IS NOT NULL

DROP procedure PROC_ORDER_WITH_RECOMPILE;

GO

CREATE procedure PROC_ORDER_WITH_RECOMPILE

with recompile --重复编译

AS

SELECT * FROM Orders;

GO

2加密存储过程

--查询存储过程,进行加密,加密后不能查看和修改源脚本

IF OBJECT_ID (N'PROC_ORDER_WITH_ENCRYPTION', N'P') IS NOT NULL

DROP procedure PROC_ORDER_WITH_ENCRYPTION;

GO

CREATE procedure PROC_ORDER_WITH_ENCRYPTION

with encryption --加密

AS

SELECT * FROM Orders;

GO

执行上述存储过程:

EXEC PROC_ORDER_WITH_ENCRYPTION

执行完的效果如图:

这就是存储过程的详细用法了,记得转发和收藏哦

SQL Server存储过程用法介绍的更多相关文章

  1. SQL Server存储过程多角度介绍

    什么是存储过程: 存储过程(Procedure)类似于C#语言中的方法,它是SQL语句和控制流语句的预编译集合.存储过程存储在数据库内,可由应用程序通过一个调用执行,而且允许用户声明变量.逻辑控制语句 ...

  2. SQL Server存储过程中使用表值作为输入参数示例

    这篇文章主要介绍了SQL Server存储过程中使用表值作为输入参数示例,使用表值参数,可以不必创建临时表或许多参数,即可向 Transact-SQL 语句或例程(如存储过程或函数)发送多行数据,这样 ...

  3. SQL Server存储过程的删除方法

    SQL Server存储过程的删除方法使我们经常会用到的,下面就为您介绍扩展存储过程的删除方法,如果您对SQL Server存储过程方面感兴趣的话,不妨一看. --清除SQL Server所有的危险扩 ...

  4. SQL Server存储过程Return、output参数及使用技巧

    SQL Server目前正日益成为WindowNT操作系统上面最为重要的一种数据库管理系统,随着 SQL Server2000的推出,微软的这种数据库服务系统真正地实现了在WindowsNT/2000 ...

  5. SQL Server 存储过程(转载)

    SQL Server 存储过程 Transact-SQL中的存储过程,非常类似于Java语言中的方法,它可以重复调用.当存储过程执行一次后,可以将语句缓存中,这样下次执行的时候直接使用缓存中的语句.这 ...

  6. 14、SQL Server 存储过程

    SQL Server 存储过程 存储过程类似函数,可以重复使用.相对于函数,存储过程拥有更强大的功能和更高的灵活性. 存储过程中可以包含逻辑控制语句和数据操作语句,可以接受参数,输出参数,返回单个值或 ...

  7. (摘录)SQL Server 存储过程

    文章摘录:http://www.cnblogs.com/hoojo/archive/2011/07/19/2110862.html SQL Server 存储过程 Transact-SQL中的存储过程 ...

  8. Sql Server 存储过程中查询数据无法使用 Union(All)

    原文:Sql Server 存储过程中查询数据无法使用 Union(All) 微软Sql Server数据库中,书写存储过程时,关于查询数据,无法使用Union(All)关联多个查询. 1.先看一段正 ...

  9. Yii2.0调用sql server存储过程并获取返回值

    1.首先展示创建sql server存储过程的语句,创建一个简单的存储过程,测试用. SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE P ...

随机推荐

  1. python第十五课——全局变量and局部变量

    全局变量&局部变量: 全局变量的特点: 1).直接定义在.py文件中(函数外)的变量(全局位置) 2).作用域比较大,可以被此文件中的任何函数所使用 局部变量的特点:1).定义在函数内部(函数 ...

  2. hdu2824 The Euler function(欧拉函数个数)

    版权声明:本文为博主原创文章,未经博主同意不得转载. vasttian https://blog.csdn.net/u012860063/article/details/36426357 题目链接:h ...

  3. istio 配置解读

    Istio在服务网络中统一提供了许多关键功能: 流量管理:控制服务之间的流量和API调用的流向,使得调用更可靠,并使网络在恶劣情况下更加健壮. 可观察性:了解服务之间的依赖关系,以及它们之间流量的本质 ...

  4. python logging模块按天滚动简单程序

    简单日志按天滚动,加入apsheduler,用crontab模式按小时运行测试: import logging from logging.handlers import TimedRotatingFi ...

  5. package.json常用的字段

    package.json中5个字段: name: 包名 今后下载时输入名称 (注意:要与下载的包名不一样) version:版本号 x.x.x 例如 1.2.3 1 大版本:当这个包有巨大内容变化时( ...

  6. MacOS在Finder中建立快速新建txt的workflow

    Mac是不支持右键直接新建txt的,因此有时候需要用到文本文稿的时候会比较麻烦.   因此这里提供一种个人认为比较方便的方法,让Mac也能很简洁的新建txt文件.   工具介绍: Automator ...

  7. 【NoSql】之Hbase

    Hbase概述 ·  Hbase是构建在hdfs上的分布式列式存储系统 ·  Hbase内部管理的文件全部存储在HDFS上面, ·  Hbase是基于google bigtable 模型开发的,典型的 ...

  8. 如何防止网页被植入广告,内容被监控-HTTPS

    前几天一朋友说访问网站页面底部怎么出现小广告了呢,内容有点不雅,朋友截图发给我,调侃我说怎么放这种广告,我一听纳闷,网站运行伊始,从来没有投放过任何广告,更别说不雅广告了. 最近还遇到一个问题就是,网 ...

  9. git 源码学习(init-db) 提交版本号 083c516331

    写在前面的废话: 学完git之后,还是感觉云里雾里的,于是乎,就想到了通过学习git源码,来加深git的熟练度,同时学习一下c语言编程. git源码学习,逐步分析 这篇帖子是逐步分析git源码的,将g ...

  10. OSG漫游到指定坐标点位置

    OSG中从当前场景位置漫游到指定点坐标位置,osg中场景的视口状态包括如下参数: 1.视点的位置 2.参考点的位置,该点通常为场景中的中心轴上的点 3.视点向上的方向向量 ( const osg::V ...