USE TEST_DEV;

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:
-- Create date:
-- Description:存储过程示例
-- =============================================
CREATE PROCEDURE PROC_DEMON
@IN_PLANT VARCHAR(20), ------- 输入参数 --------
@IN_ASSEMBLY VARCHAR(20),
@IN_SUPPLIER VARCHAR(20),
@IN_DOCK VARCHAR(20),
@IN_PARTS VARCHAR(20),
@IN_PART_NUM INT,
@OUTPUT INT OUTPUT ------- 输出参数 --------
AS
BEGIN ------- 创建变量 --------
DECLARE @PLANT VARCHAR(20);
DECLARE @ASSEMBLY_LINE VARCHAR(20);
DECLARE @SUPPLIER_NUM VARCHAR(20);
DECLARE @DOCK VARCHAR(20);
DECLARE @BOX_PARTS VARCHAR(20);
DECLARE @PART_NUM INT; -------- 创建临时表 --------
CREATE TABLE #TEMP([PLANT] VARCHAR(20),[ASSEMBLY_LINE] VARCHAR(20),[SUPPLIER_NUM] VARCHAR(20),[DOCK] VARCHAR(20),[BOX_PARTS] VARCHAR(20),[PART_NUM] INT)
-------- 插入数据 --------
INSERT #TEMP(PLANT,ASSEMBLY_LINE,SUPPLIER_NUM,DOCK,BOX_PARTS,PART_NUM)
VALUES (@IN_PLANT,@IN_ASSEMBLY,@IN_SUPPLIER,@DOCK,@IN_PARTS,@IN_PART_NUM); -------- 创建游标 --------
DECLARE cur1 CURSOR FOR SELECT [PLANT],[ASSEMBLY_LINE],[SUPPLIER_NUM],[DOCK],[BOX_PARTS],[PART_NUM]
FROM #TEMP
WHERE PLANT IS NOT NULL
GROUP BY [PLANT],[ASSEMBLY_LINE],[SUPPLIER_NUM],[DOCK],[BOX_PARTS],[PART_NUM]; -------- 打开游标并填充数据 --------
OPEN cur1
FETCH NEXT FROM cur1 INTO @PLANT,@ASSEMBLY_LINE,@SUPPLIER_NUM,@DOCK,@BOX_PARTS,@PART_NUM
PRINT @@FETCH_STATUS;
WHILE (@@FETCH_STATUS = 0)
BEGIN
DECLARE @PARTNUM INT;
SELECT @PARTNUM = ISNULL(PART_NUM,0) FROM #TEMP WHERE BOX_PARTS IS NOT NULL;
IF @PARTNUM > 0 BEGIN
SET @OUTPUT = 1;
END
ELSE BEGIN
SET @OUTPUT = 0;
END
-------- 填充下一条数据 --------
FETCH NEXT FROM cur1 INTO @PLANT,@ASSEMBLY_LINE,@SUPPLIER_NUM,@DOCK,@BOX_PARTS,@PART_NUM
-------- 查看游标状态 --------
PRINT @@FETCH_STATUS;
END
CLOSE cur1 SELECT * FROM #TEMP;
-------- 删除临时表 --------
--DROP TABLE #TEMP;
-------- 返回值 --------
RETURN 1;
END
GO SET QUOTED_IDENTIFIER ON
SET ANSI_NULLS ON
GO --DROP PROC dbo.PROC_DEMON -------- 带输入输出参数 ---------
--DECLARE @RESULT AS INT;
--EXEC dbo.PROCDEMON
-- @IN_PLANT = 'I033',
-- @IN_ASSEMBLY = 'AF01',
-- @IN_SUPPLIER = 'LOC',
-- @IN_DOCK = 'LOC05',
-- @IN_PARTS = 'ZONE1',
-- @IN_PART_NUM = 0,
-- @OUTPUT = @RESULT OUTPUT
--SELECT @RESULT AS RESULT; -------- 带输入输出带返回值 ---------
DECLARE @RESULT AS INT,
@STATUS AS INT = 0;
EXEC @STATUS = dbo.PROC_DEMON
@IN_PLANT = 'I033',
@IN_ASSEMBLY = 'AF01',
@IN_SUPPLIER = 'LOC',
@IN_DOCK = 'LOC05',
@IN_PARTS = 'ZONE1',
@IN_PART_NUM = 11,
@OUTPUT = @RESULT OUTPUT
SELECT @RESULT AS RESULT,@STATUS AS STATUS;

SQL SERVER 存储过程示例的更多相关文章

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

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

  2. SQL server存储过程语法及实例(转)

    存储过程如同一门程序设计语言,同样包含了数据类型.流程控制.输入和输出和它自己的函数库. --------------------基本语法-------------------- 一.创建存储过程cr ...

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

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

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

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

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

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

  6. 14、SQL Server 存储过程

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

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

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

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

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

  9. C# 调用存储过程 Sql Server存储过程 存储过程报错,程序中的try

    C#程序调用Sql Server存储过程,存储过程中报错情况,返回值... 0.SQL存储过程 USE [Opos] GO /****** Object: StoredProcedure [dbo]. ...

随机推荐

  1. POJ 2315:Football Game(博弈论)

    [题目链接] http://poj.org/problem?id=2315 [题目大意] 两名球员轮流从N个球中挑出不多于M个射门,每个球半径都是R,离球门S. 每次只能踢出L以内的距离.进最后一个球 ...

  2. 【bzoj2142】【礼物】拓展Lucas定理+孙子定理

    (上不了p站我要死了,侵权度娘背锅) Description 一年一度的圣诞节快要来到了.每年的圣诞节小E都会收到许多礼物,当然他也会送出许多礼物.不同的人物在小E 心目中的重要性不同,在小E心中分量 ...

  3. 10.2(java学习笔记)JDBC事务简述

    一.事务 事务是指作为一系列操作组成的一个整体,该整体只有两种状态,要么全部执行,要么全部不执行. 当组成这个事务的所有语句都执行成功则该事务执行,只要有一条语句执行失败则该事务不执行. 假设这里有一 ...

  4. Scala实战高手****第6课 :零基础实战Scala集合操作及Spark源码解析

    本课内容1.Spark中Scala集合操作鉴赏2.Scala集合操作实战 --------------------------------------------------------------- ...

  5. Radius报文解析(转)

    RADIUS ,是远程认证拨号用户服务的简称.RADIUS原先设计的目的是为拨号用户进行认证和计费.后来经过多次改进,形成了一项通用的认证计费协议,主要完成在网络接入设备和认证服务器之间承载认证.授权 ...

  6. iOS开发——随机数的使用

    1).arc4random() 比较精确不需要生成随即种子        使用方法 :                  通过arc4random() 获取0到x-1之间的整数的代码如下:       ...

  7. javascript快速入门15--表单

    大多数Web页面与用户之间的交互都发生在表单中,表单中有许多交互式HTML元素如:文本域,按钮,复选框,下拉列表等.从文档对象层次图中可以看到,表单是包含在文档中的,所以要访问表单,仍然需要通过doc ...

  8. JavaScript Array reverse 方法:颠倒数组中元素的顺序

    在JavaScript中,Array对象的reverse()方法将颠倒(反转)数组中元素的顺序.arr.reverse()在原数组上实现这一功能,即,reverse()会改变原数组. 例1:将数组元素 ...

  9. ibatis中使用List作为传入参数的使用方法及 CDATA使用

    ibatis中list做回参很简单,resultClass设为list中元素类型,dao层调用: (List)getSqlMapClientTemplate().queryForList(" ...

  10. KVO(Key Value Observing)

    *KVO能够监听某个对象属性的改变 原理:仅仅要给一个对象注冊一个监听,那么在执行时, 系统就会自己主动给该对象生成一个子类对象,而且重写自己主动生成的子类对象的被监听属性的set方法.然后在set方 ...