分析SQL Server里函数的两种用法
2025-11-29 06:30:16阅读量:7 字体:大 中 小
1.因为update里不能用存储过程,然而要根据更新表的某些字段还要进行计算。我们常常采用游标的方法,这里用函数的方法实现。
函数部分:
CREATE FUNCTION [DBO].[FUN_GETTIME] (@TASKPHASEID INT)
RETURNS FLOAT AS
BEGIN
DECLARE @TASKID INT,
@HOUR FLOAT,
@PERCENT FLOAT,
@RETURN FLOAT
IF @TASKPHASEID IS NULL
BEGIN
RETURN(0.0)
END
SELECT @TASKID=TASKID,@PERCENT=ISNULL(WORKPERCENT,0)/100
FROM TABLETASKPHASE
WHERE ID=@TASKPHASEID
SELECT @HOUR=ISNULL(TASKTIME,0) FROM TABLETASK
WHERE ID=@TASKID
SET @RETURN=@HOUR*@PERCENT
RETURN (@RETURN)
END
调用函数的存储过程部分:
CREATE PROCEDURE [DBO].[PROC_CALCCA]
@ROID INT
AS
BEGIN
DECLARE @CA FLOAT
UPDATE TABLEFMECA
SET
Cvalue_M= ISNULL(MODERATE,0)*ISNULL(FMERATE,0)
*ISNULL(B.BASFAILURERATE,0)*[DBO].[FUN_GETTIME](C.ID)
FROM TABLEFMECA ,TABLERELATION B,TABLETASKPHASE C
WHERE ROID=@ROID AND TASKPHASEID=C.ID AND B.ID=@ROID
SELECT @CA=SUM(ISNULL(Cvalue_M,0)) FROM TABLEFMECA WHERE ROID=@ROID
UPDATE TABLERELATION
SET CRITICALITY=@CA
WHERE ID=@ROID
END
GO
2.大家要根据某表的某些记录,先计算后求和,因为无法存储中间值,平时我们也用游标的方法进行计算。但sqlserver2000里支持:
SUM ( [ ALL | DISTINCT ] expression )
expression
是常量、列或函数,或者是算术、按位与字符串等运算符的任意组合。因此我们可以利用这一功能。
函数部分:
CREATE FUNCTION [DBO].[FUN_RATE] (@PARTID INT,@ENID INT,@SOURCEID INT,
@QUALITYID INT,@COUNT INT)
RETURNS FLOAT AS
BEGIN
DECLARE @QXS FLOAT, @G FLOAT, @RATE FLOAT
IF (@ENID=NULL) OR (@PARTID=NULL) OR (@SOURCEID=NULL) OR (@QUALITYID=NULL)
BEGIN
RETURN(0.0)
END
SELECT @QXS= ISNULL(XS,0) FROM TABLEQUALITY WHERE ID=@QUALITYID
SELECT @G=ISNULL(FRATE_G,0) FROM TABLEFAILURERATE
WHERE (SUBKINDID=@PARTID) AND( ENID=@ENID) AND ( DATASOURCEID=@SOURCEID)
AND( ( (ISNULL(MINCOUNT,0)=ISNULL(@COUNT,0)))
OR(ISNULL(@COUNT,0)>ISNULL(MAXCOUNT,0)))
SET @RATE=ISNULL(@QXS*@G,0)
RETURN (@RATE)
END
调用函数的存储过程部分:
CREATE PROC PROC_FAULTRATE
@PARTID INTEGER, @QUALITYID INTEGER, @SOURCEID INTEGER, @COUNT INTEGER,
@ROID INT, @GRADE INT,@RATE FLOAT=0 OUTPUTAS
BEGIN
DECLARE
@TASKID INT
SET @RATE=0.0
SELECT @TASKID=ISNULL(TASKPROID,-1) FROM TABLERELATION WHERE
ID=(SELECT PID FROM TABLERELATION WHERE ID=@ROID)
IF (@TASKID=-1) OR(@GRADE=1) BEGIN
SET @RATE=0
RETURN
END
SELECT @RATE=SUM([DBO].[FUN_RATE] (@PARTID,ENID,@SOURCEID,
@QUALITYID,@COUNT) *ISNULL(WORKPERCENT,0)/100.0)
FROM TABLETASKPHASE
WHERE TASKID=@TASKID
END
GO
函数还可以返回表等,希望大家一起讨论sqlserver里函数的妙用。
免责声明:
本文《分析SQL Server里函数的两种用法》版权归原作者所有,内容不代表本站立场!
如本文内容影响到您的合法权益(含文章中内容、图片等),请及时联系本站,我们会及时删除处理。
推荐阅读

什么是Infinex?一文了解Infinex账户创建、奖励及风险
目录什么是 Infinex?我能用 Infinex 做什么?Infinex 账户说明如何创建 Infinex 账户什么是 Infinex 赞助人?如何获得 Infinex 奖励Infinex 是否接受...
阅读: 256

小白科普买币能直接到Web3钱包里吗?安全吗?
目录买币能直接到Web3钱包里吗?买币直接到Web3钱包里安全吗?Web3钱包怎么出金?Web3钱包随着技术的发展,逐渐在市场展露头角,从资产存储工具转变为去中心化多链网络中身份和资产管理的中心枢纽。...
阅读: 241

okpay钱包如何补充手续费?有哪些方法?一文详解
目录什么是转账手续费提币需要多少手续费如何通过收币方式为钱包补充手续费如何通过交易所提币快捷补充钱包手续费当您从钱包向交易所或其他钱包发起转账时,矿工需要把交易打包并放上区块链,才能使交易完成。这个过...
阅读: 247

Trezor与Ledger钱包对比:您应该选择哪款硬件钱包?
目录Trezor与Ledger硬件钱包:主要区别Trezor与Ledger硬件钱包:安全性Trezor硬件钱包Ledger硬件钱包Ledger与Trezor:哪个安全性更高?Trezor与Ledger...
阅读: 210

币安钱包上线网页版:享受更智能、更快捷的交易体验
目录什么是安全自动签名 (SAS)?安全自动签名 (SAS) 授权和工作阶段过期是如何运作的?我可以在币安钱包 (网页版) 上购买加密资产吗?币安钱包 (网页版) 支持哪些区块链?使用币安钱包 (We...
阅读: 239

比特币钱包安全:休眠钱包与量子计算如何计算未来?一文分析
目录理解比特币钱包与休眠钱包为什么休眠比特币钱包正在重新激活?比特币钱包面临的量子计算威胁量子计算如何影响比特币量子风险的时间表目标冻结比特币钱包的诈 骗如何保护您的比特币钱包机构采用及其对比特币钱包...
阅读: 216
币安入金教学2025.8.22:信用卡、Apple Pay、C2C、虚拟货币钱包入金图文方法
目录在介绍币安入金买币之前,我们给大家先介绍下国内使用最多的加密货币交易所,这样可以帮助大家有更好的选择!币安交易所入金前准备1.C2C交易入金– 适合想法币大额入金、不怕麻烦的人2. A...
阅读: 263
KuCoin交易所怎么样?安全吗?合法吗?KuCoin功能、手续费介绍
目录国内使用最多的加密货币交易所排名KuCoin 交易所是什么?交易所基础信息KuCoin 交易所优缺点KuCoin 交易所安全性如何?是诈 骗吗?是否有倒闭风险?1.暂未获得任何金融监管2. 有公开...
阅读: 243
币安出金安全吗?币安美元电汇、钱包转帐、购买虚拟卡、C2C法币提现教学
目录币安交易所出金前准备1. C2C出金—— 适合想直接转换法币、时间很多的人2. 加密货币出金—— 适合新手、老手、懒人AKA所有人3. 美元电汇出金...
阅读: 221

2025最新欧亿交易所攻略:ok交易所简单赚币操作教学
目录OKX 简单赚币是什么?OKX 简单赚币「活期」与「定期」的差别?简单赚币还有什么特别的奖励?OKX 简单赚币操作教学?OKX 简单赚币步骤一:进入简单赚币页面OKX 简单赚币步骤二:选择要申购的...
阅读: 237
猜你喜欢

硬件钱包是什么?如何运作?优化资产保护的10个安全提示详解
2025-10-29

如何获得欧意20%手续费及30USDT合约开仓券?
2025-10-29

虚拟币交易APP有哪些?2025年虚拟币交易APP最新排行榜
2025-10-29

全球排名前十的虚拟货币实时行情软件APP盘点
2025-10-29
新手注册欧易OKX账号攻略(安全下载安装注册入门指南)
2025-10-29

2025全球TOP20虚拟货币交易所排名评价:一文教你交易所怎么选
2025-10-29

币圈十大加密货币交易所app排行榜介绍(2025年最新排名)
2025-10-29

国内正规合法的虚拟币平台有哪些?在哪下载安装正规合法的虚拟币平台?
2025-10-29

虚拟币账户在哪申请注册?虚拟币平台简介及创建账户教学2025版
2025-10-29
