SQL Server里函数的两种用法(可以代替游标)
1、因为update里不能用存储过程,然而要根据更新表的某些字段还要进行计算。我们常常采用游标的方法,这里用函数的方法实现。 中.国.站长站
函数部分: Www^Chinaz^com
| 以下为引用的内容: CREATE FUNCTION [DBO].[FUN_GETTIME] (@TASKPHASEID INT)
Chinaz.com CREATE PROCEDURE [DBO].[PROC_CALCCA] 站.长站 |
2、我们要根据某表的某些记录,先计算后求和,因为无法存储中间值,平时我们也用游标的方法进行计算。但sqlserver2000里支持 Www@Chinaz@com
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)) AND ( ISNULL(MAXCOUNT,0)>=ISNULL(@COUNT,0))) 站.长.站 OR(ISNULL(@COUNT,0)>ISNULL(MAXCOUNT,0))) SET @RATE=ISNULL(@QXS*@G,0) RETURN (@RATE) END |
调用函数的存储过程部分:
| 以下为引用的内容: CREATE PROC PROC_FAULTRATE Chinaz~com WHERE TASKID=@TASKID END GO Chinaz |
