当前位置:首页 > 系统运维 > 正文内容

SQL Server函数的两种实际用法

a8116255316年前 (2010-06-30)系统运维8

下面的文章主要分析的是 SQL Server函数的两种实际用法,以及对其在实际应用中我们经常能用到代码的介绍,以下就是SQL Server函数的两种实际用法具体的描述,希望在你今后的学习中会有所帮助。

SQL Server函数的两种用法(可以代替游标)

分析 SQL Server里函数用法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 @TASKIDTASKID=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_MISNULL(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  

分析 SQL Server函数用法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 @QXSISNULL(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   @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函数用法的介绍,望你能有所收获。

扫描二维码推送至手机访问。

版权声明:本文由2345好导航站长资讯发布,如需转载请注明出处。

本文链接:http://2345hao.cn/blog/index.php/post/21375.html

分享给朋友:

“SQL Server函数的两种实际用法” 的相关文章

windows 7系统如何设置休眠时不断网以便继续完成下载

windows 7系统如何设置休眠时不断网以便继续完成下载

在Windows 7系统的默认设置中,当Windows 7系统处于休眠状态时,会同时断网的。如此一来,无论你正在使用迅雷还是快车等下载工具,同样可以在休眠状态下继续完成下载,最大限度做到从身边的小事开始支持环保。下面我们就详细介绍操作步骤,帮助Windows 7系统用户实现这一节能目标。 首先需要...

windows 7系统开机提示press any key to restart的故障分析及解

windows 7系统开机提示press any key to restart的故障分析及解

Windows 7 64位系统开机后提示"press any key to restart",无法进入系统了,具体现象如下所示: 故障分析: 故障的主要原因还是硬盘的问题,可以先检查是不是接触不良或坏了,进行修复或更换即可。 解决方法: 1、开机按F8不动到高级选项出现在松手,选“...

Windows7开机后出现黑一下屏性能降低

Windows7开机后出现黑一下屏性能降低

打开IE浏览器的时候、聊QQ的时候、玩游戏的时候… … 这到底是谁惹的祸呢? 很多人都知道Windows 7桌面特效全部开启会使系统性能降低,那到底是哪个特效导致的这一情况呢? 解决办法: 右键计算机,高级系统设置-性能-设置-关闭”任务栏和开始菜单使用动画“和”最大化和最小化动态显示窗口“...

上帝不止一个 更多Windows7 快捷模式.

上帝不止一个 更多Windows7 快捷模式.

国外媒体CNET NEWS就这个“上帝模式”和微软Windows部门主管Steven Sinofsky进行邮件交流后得知,这其实只是众多快捷方式中的一个,Sinofsky在邮件里给出了十多个这类快捷方式的关键字符串。 它们的建立方法和之前的“上帝模式”一样,在任意位置新建的一个文件夹,然后改名即可...

解决windows 7无法将程序锁定到任务栏或附到开始菜单的方法

解决windows 7无法将程序锁定到任务栏或附到开始菜单的方法

出现该问题的原因是由于使用第三方优化软件消除快捷方式的小箭头引起的。 1、在开始搜索框中键入“regedit”,按回车键打开注册表编辑器。 2、依次定位到以下分支:HKEY_CLASSES_ROOTlnkfile。 3、在lnkfile项上鼠标右键单击“新建”——“字符串值”。...

ubuntu14.04打开个几个应用窗口最小化后怎么切换呢?

ubuntu14.04打开个几个应用窗口最小化后怎么切换呢?

ubuntu14.04应用窗口列表在哪里?在ubuntu下打开个几个应用窗口最小化后怎么切换呢,应用窗口列表在哪里呢? 1、多打开几个chrome浏览器窗口。 2、然后都做最小化处理。 3、现在我们在桌面左边的面板上找到"左右两边有小白点"的chrome浏览器应用图标,这就是chr...