什么是存储过程呢?
存储过程就是作为可执行对象存放在数据库中的一个或多个SQL命令。
通俗来讲:存储过程其实就是能完成一定操作的一组SQL语句。

那为什么要用存储过程呢?
1.存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。
2.当对数据库进行复杂操作时,可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。
3.存储过程可以重复使用,可减少数据库开发人员的工作量。
4.安全性高,可设定只有某些用户才具有对指定存储过程的使用权

那存储过程怎么用呢?

以下通过表feili来了解存储过程,因为是要了解存储过程的简单用法,所以所有例子均很简单。

无参数存储过程:
选出feili表中的所有信息,

ALTER PROCEDURE [dbo].[feili]
AS
BEGIN
  -- routine body goes here, e.g.
  -- SELECT 'Navicat for SQL Server'
SELECT * FROM FEILIPOINT
END

有参数存储过程:
全局变量
全局变量也称为外部变量,是在函数的外部定义的,它的作用域为从变量定义处开始,到本程序文件的末尾。
选出指定id的肥力信息:

ALTER PROCEDURE [dbo].[feili]
(@OBJECTID nvarchar(100))
AS
DECLARE @sql1 nvarchar(MAX);
BEGIN
SET @sql1='SELECT * FROM FEILIPOINT where OBJECTID='+@OBJECTID
EXEC sp_executesql @sql1;
END

上面是在外部给变量赋值,也可以在内部直接给变量设置默认值

ALTER PROCEDURE [dbo].[feili]
(@OBJECTID nvarchar(100)='1')
AS
BEGIN
SELECT * FROM FEILIPOINT where OBJECTID=@OBJECTID
EXEC feili;
END

也可以把变量的内容输出,使用output

 

ALTER PROCEDURE [dbo].[feili]
(
@OBJECTID nvarchar(100)
)
AS
DECLARE @sql1 nvarchar(MAX);
DECLARE @num INT;
BEGIN
SET @sql1='SELECT @num=count(*) FROM FEILIPOINT where OBJECTID='+@OBJECTID
EXEC sp_executesql @sql1,N'@num int output',@num OUTPUT;
SELECT @num;
END

以上是全局变量,下面来了解局部变量
局部变量也称为内部变量。局部变量是在函数内作定义说明的。其作用域仅限于函数内部,离开该函数后再使用这种变量是非法的。
局部变量的定义:必须先用Declare命令定以后才可以使用,declare{@变量名 数据类型}
局部变量的赋值方法:set{@变量名=表达式}或者select{@变量名=表达式}
局部变量的显示:select @变量名

ALTER PROCEDURE [dbo].[feili]
AS
DECLARE @objectid nvarchar(100);
BEGIN
DECLARE @sql1 nvarchar(MAX);
SET @objectid='10';
SET @sql1='SELECT * FROM FEILIPOINT WHERE objectid='+@objectid;
EXEC sp_executesql @sql1;
END

也可以这样写

ALTER PROCEDURE [dbo].[feili]
AS
DECLARE @objectid nvarchar(100);//该变量若需要动态使用,还需要在exec中进行声明
BEGIN
DECLARE @sql1 nvarchar(MAX);
SET @objectid='10';
SET @sql1='SELECT * FROM FEILIPOINT WHERE objectid=@objectid';
EXEC sp_executesql @sql1,N'@objectid nvarchar(max)',@objectid;
END

  

最新文章

  1. Mysql基本语句的总结
  2. ListView中的setOnScrollListener
  3. 使用多文档接口(Multiple Document Interface) 一
  4. 5天玩转C#并行和多线程编程 —— 第一天 认识Parallel
  5. PHP非阻塞模式 (转自 尘缘)
  6. SQL Server 2016将内置R语言?
  7. DateFormatUtil.java
  8. iScroll.js和swiper.js
  9. java之RTTI和反射的理解
  10. 利用Java实现表达式二叉树
  11. Cow Sorting(置换)
  12. Linux 精准获取进程pid--转
  13. Gradle 1.12用户指南翻译——第三十四章. JaCoCo 插件
  14. JMeter Concurrency Thread Group阶梯式加压
  15. python Flask web框架
  16. [C][代码实例]冒泡排序
  17. 在windows下搭建vueJS开发环境
  18. Docker 开发最佳实践
  19. [转]C++之运算符重载(1)
  20. [转]一步一步部署SSIS包图解教程

热门文章

  1. Tomcat 默认应用
  2. ORACLE触发器概述之【语句触发器】【weber出品】
  3. 给软件增加注册功能 c#
  4. 在windows下获取硬盘序列号(win7 32位,Windows Server 64位测试,希望在其他平台测试,遇到问题的网友留言分享)
  5. 九章算法系列(#3 Binary Tree & Divide Conquer)-课堂笔记
  6. iPhone 和Android应用,特殊的链接:打电话,短信,email;
  7. mysql主从数据库复制
  8. hdu 1853 最小费用流好题 环的问题
  9. logstash date插件介绍
  10. ThreadPoolExecutor参数解析