欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【分析MS SQL Server里函数的两种用法】,下面是详细的分享!
分析MS SQL Server里函数的两种用法
SQL Server里函数的两种用法(可以代替游标)
1、因为update里不能用存储过程,然而要根据更新表的某些字段还要进行计算。我们常常采用游标的方法,这里用函数的方法实现。
函数部分:
| 以下为引用的内容: CREATE FUNCTION [DBO].[FUN_GETTIME] (@TASKPHASEID INT)
CREATE PROCEDURE [DBO].[PROC_CALCCA] |
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)) 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 |
函数还可以返回表等,希望大家一起讨论sqlserver里函数的妙用。
以上所分享的是关于分析MS SQL Server里函数的两种用法,下面是编辑为你推荐的有价值的用户互动:
相关问题:在sql server中怎么使用avg函数
答:avg函数在sqlserver中是求平均数的函数,用法与其他聚合函数,如count,sum等类似。 如,表test中有如下数据 id grade 1 100 1 90 1 80 2 80 2 70 3 90 现在要求每个id的平均值,可以用如下语句 select id,avg(grade) as avggrade from test gro... >>详细
相关问题:sql server里面和wmsys.wm_concat()函数相等的函数...
答:没有用过,不过你可以自己写一个这样的存储函数就可以了,很简单的 >>详细
相关问题:MS SQL SERVER中,case when then end 的用法
答:A. 使用带有简单 CASE 函数的 SELECT 语句 在 SELECT 语句中,简单 CASE 函数仅检查是否相等,而不进行其他比较。 以下示例使用 CASE 函数更改产品系列类别的显示,以使这些类别更易理解。 USE AdventureWorks;GOSELECT ProductNumber, Category... >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
