SQL Server存储过程中变量使用函数调用变量
USE DB名称
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
.
CREATE PROCEDURE 存储过程名
@formID nvarchar(20) , --传入参数
@Error int output
AS
DECLARE @DayID NVARCHAR(10) --当前日期
DECLARE @GLFDayID NVARCHAR(10) --費用計算日
DECLARE @EmpID NVARCHAR(50) --人员工号
DECLARE @TFormDayID NVARCHAR(10) -- 填单日期
DECLARE @LWorkDay NVARCHAR(10) --最后工作日
BEGIN
--给人员工号变量赋值
SELECT @EmpID=EmpID FROM 离职表签核总表 WHERE FormID=@formID --(传入单号变量)
--新建一个temp表并插入temp表中離職人員所有請的非曠工假與實數
INSERT INTO temp表 (VocaEmpID,VocaEmpName,VocaDayID,VocaTotalHours,ColType)
SELECT VocaEmpID,VocaEmpName,VocaDayID,A.VocaTotalHours,ColType
FROM 请假明细表 A, 离职表签核总表 B
WHERE A.CurrentStatus='5' AND A.VocaEmpID=B.EmpID AND A.ColType!='C04' ORDER BY VocaEmpID DESC
--更新臨時表中的人員责任制类型
UPDATE temp表 SET IsDuty=A.IsDuty
FROM 人员信息表 A, temp表 B
WHERE A.EmpID=B.VocaEmpID
--给变量赋值 [dbo].[RSN_FC_CostDay](EmpID) 为函数方法
SELECT @DayID=CONVERT(NVARCHAR(10),GETDATE(),111),@EmpID=EmpID ,@TFormDayID=CONVERT(NVARCHAR(10),ApDate,111) ,@GLFDayID=[dbo].[RSN_FC_CostDay](EmpID) FROM 离职表签核总表 WHERE FormID=@formID
SELECT @LWorkDay=MAX(VocaDayID) FROM 请假明细表 WHERE VocaEmpID=@EmpID AND ColType='C04' AND CurrentStatus='5'
INSERT INTO HCB汇总表
(DayID ,
FormNID ,
EmpID ,
TFormDayID ,
LWorkDay ,
GLFDayID ,
IsTB ,
CUser ,
CDate ,
LUser ,
LDate
)
VALUES
(@DayID ,
@formID,
@EmpID ,
@TFormDayID ,
@LWorkDay ,
@GLFDayID ,
N'N' ,
N' ' ,
GETDATE() ,
N' ' ,
GETDATE()
)
SET @Error= @@ERROR
TRUNCATE TABLE temp表
END
SQL Server存储过程中变量使用函数调用变量的更多相关文章
- SQL Server存储过程中使用表值作为输入参数示例
这篇文章主要介绍了SQL Server存储过程中使用表值作为输入参数示例,使用表值参数,可以不必创建临时表或许多参数,即可向 Transact-SQL 语句或例程(如存储过程或函数)发送多行数据,这样 ...
- Sql Server 存储过程中查询数据无法使用 Union(All)
原文:Sql Server 存储过程中查询数据无法使用 Union(All) 微软Sql Server数据库中,书写存储过程时,关于查询数据,无法使用Union(All)关联多个查询. 1.先看一段正 ...
- sql server 存储过程中使用变量表,临时表的分析(续)
最近,我有一朋友,对我说他的数据库中的很多存储过程,执行都是超时.让我替他看看是什么原因.我一看,原来他的存储过程中用了很多的临时表与变量表.于是我跟他说过犹不及. 在存储过程中使用临时表或变量表,使 ...
- 【转】SQL SERVER 存储过程中变量的作用域
今天遇到一个很有趣的事情,以前没有注意过,所以记下来. 先来看例子. SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE PROCEDURE ...
- sql server存储过程中SELECT 与 SET 对变量赋值的区别
SQL Server 中对已经定义的变量赋值的方式用两种,分别是 SET 和 SELECT. 对于这两种方式的区别,SQL Server 联机丛书中已经有详细的说明,但很多时候我们 并没有注意,其实这 ...
- 【转】sql server存储过程中SELECT 与 SET 对变量赋值的区别
转自:http://www.cnblogs.com/micheng11/archive/2008/07/08/1237905.html SQL Server 中对已经定义的变量赋值的方式用两种,分别是 ...
- sql server存储过程中SELECT 与 SET 对变量赋值的区别 转自Theo
SQL Server 中对已经定义的变量赋值的方式用两种,分别是 SET 和 SELECT. 对于这两种方式的区别,SQL Server 联机丛书中已经有详细的说明,但很多时候我们 并没有注意,其实这 ...
- SQL Server 存储过程中处理多个查询条件的几种常见写法分析,我们该用那种写法
本文出处: http://www.cnblogs.com/wy123/p/5958047.html 最近发现还有不少做开发的小伙伴,在写存储过程的时候,在参考已有的不同的写法时,往往很迷茫,不知道各种 ...
- SQL Server存储过程中防止线程重入处理方式
对于线程重入,在C#中有lock关键字锁住一个SyncObject,而SQL Server也可用一个表来模拟实现. 先创建一个同步表,相当于C#中的SyncObject,并插入一条记录(初始值为1) ...
- sql server 存储过程中,调用事务 tran
Sql Server 2005/2008中提供了begin tran,commit tran和rollback tran来使用事务. begin tran表示开始事务, commit tran表示 ...
随机推荐
- MATLAB中 H(b > g) = 2*pi - H(b > g); 作何解
H(b > g) = 2*pi - H(b > g); %b > g 会得到一个逻辑矩阵,如b=[7,5,6] ;g=[1,2,8],那么b>g会得到[1,1,0]: b< ...
- keep-alive 实现从列表页到详情页,然后再回到列表页并保持原来列表页的页码数,并且只刷新数据
思路: keep-alive应用场景介绍 <keep-alive> 不会在函数式组件中正常工作,因为它们没有缓存实例.结合router,缓存部分页面 activated 和 deactiv ...
- Tosca IE 浏览器的Internet Options 配置, 解决login很慢的问题
Screen 1-3 Screen 4-6 Screen 7
- 小D课堂 - 零基础入门SpringBoot2.X到实战_第8节 数据库操作之整合Mybaties和事务讲解_32..SpringBoot2.x持久化数据方式介绍
笔记 1.SpringBoot2.x持久化数据方式介绍 简介:介绍近几年常用的访问数据库的方式和优缺点 1.原始java访问数据库 开发流程麻烦 ...
- flutter 日志工具类
class LogUtils { //dart.vm.product 环境标识位 Release为true debug 为false static const bool isRelease = con ...
- Python之BeautifulSoup的使用示例
import requests from bs4 import BeautifulSoup url = 'http://pm25.in/'+city_pinyin r = requests.get(u ...
- LeetCode_326. Power of Three
326. Power of Three Easy Given an integer, write a function to determine if it is a power of three. ...
- python2:输出百分比
pass_num=80execute_num=90pass_rate = "%.2f%%" % (float(pass_num)/float(executed_num)*100)p ...
- CF1277D Let's Play the Words?
思路: 字符串其实只有0...0, 0...1, 1...0, 1...1四种. 实现: #include <bits/stdc++.h> using namespace std; ]; ...
- 2019年广东省赛gdccpc回顾
本次比赛状态一般般,热身赛单人挂机爆零让自己慌了一整天. 开题直接抓E题入手,准备交题后关机(辣鸡云桌面),开机后又告诉我要关机,心急连交两发结果都WA了,最后靠队员提醒救了回来.心态还算稳住了.后面 ...