讲解SQLServer数据库中函数的使用方法

导读:本文主要主要讲解了SQL Server数据库中函数的两种用法,具体内容请参考下文:

创新互联公司专注于企业网络营销推广、网站重做改版、蕉岭网站定制设计、自适应品牌网站建设、H5页面制作成都做商城网站、集团公司官网建设、成都外贸网站建设公司、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为蕉岭等各大城市提供网站开发制作服务。

  1. 由于update里不能用存储过程,并且由于根据更新表的某些字段还要进行计算。所以很多人采用的是游标的方法,在这里我们可以用函数的方法实现。

  函数部分:

 
 
 
  1.  CREATE FUNCTION [DBO].[FUN_GETTIME] (@TASKPHASEID INT)  
  2.   RETURNS FLOAT AS 
  3.   BEGIN 
  4.   DECLARE @TASKID INT,  
  5.   @HOUR FLOAT,  
  6.   @PERCENT FLOAT,  
  7.   @RETURN FLOAT 
  8.   IF @TASKPHASEID IS NULL 
  9.   BEGIN 
  10.   RETURN(0.0)  
  11.   END 
  12.   SELECT @TASKID=TASKID,@PERCENT=ISNULL(WORKPERCENT,0)/100  
  13.   FROM TABLETASKPHASE  
  14.   WHERE ID=@TASKPHASEID  
  15.   SELECT @HOUR=ISNULL(TASKTIME,0) FROM TABLETASK  
  16.   WHERE ID=@TASKID  
  17.   SET @RETURN=@HOUR*@PERCENT  
  18.   RETURN (@RETURN)  
  19.   END 

   调用函数的存储过程部分:

 
 
 
  1. CREATE PROCEDURE [DBO].[PROC_CALCCA]  
  2.   @ROID INT 
  3.   AS 
  4.   BEGIN 
  5.   DECLARE @CA FLOAT 
  6.   UPDATE TABLEFMECA  
  7.   SET 
  8.   Cvalue_M= ISNULL(MODERATE,0)*ISNULL 
  9.   (FMERATE,0)*ISNULL(B.BASFAILURERATE,0)*[DBO].[FUN_GETTIME](C.ID)  
  10.   FROM TABLEFMECA ,TABLERELATION B,TABLETASKPHASE C  
  11.   WHERE ROID=@ROID AND TASKPHASEID=C.ID AND B.ID=@ROID  
  12.   SELECT @CA=SUM(ISNULL(Cvalue_M,0)) FROM TABLEFMECA WHERE ROID=@ROID  
  13.   UPDATE TABLERELATION  
  14.   SET CRITICALITY=@CA  
  15.   WHERE ID=@ROID  
  16.   END 
  17.   GO  

    2. 我们要根据某表的某些记录,先计算后求和,因为无法存储中间值,平时我们也用游标的方法进行计算。但SQL Server 2000里支持。

  SUM ( [ ALL DISTINCT ] eXPression )
  expression

  是常量、列或函数,或者是算术、按位与字符串等运算符的任意组合。因此我们可以利用这一功能。

  函数部分:

 
 
 
  1.  CREATE FUNCTION [DBO].[FUN_RATE] (@PARTID INT,  
  2.   @ENID INT,@SOURCEID INT, @QUALITYID INT,@COUNT INT)  
  3.   RETURNS FLOAT AS 
  4.   BEGIN 
  5.   DECLARE @QXS FLOAT, @G FLOAT, @RATE FLOAT 
  6.   IF (@ENID=NULL) OR (@PARTID=NULL) OR (@SOURCEID=NULL) OR (@QUALITYID=NULL)  
  7.   BEGIN 
  8.   RETURN(0.0)  
  9.   END 
  10.   SELECT @QXS= ISNULL(XS,0) FROM TABLEQUALITY WHERE ID=@QUALITYID  
  11.   SELECT @G=ISNULL(FRATE_G,0) FROM TABLEFAILURERATE  
  12.   WHERE (SUBKINDID=@PARTID)  
  13.   AND( ENID=@ENID)  
  14.   AND ( DATASOURCEID=@SOURCEID)  
  15.   AND( ( (ISNULL(MINCOUNT,0)<=ISNULL(@COUNT,0))  
  16.   AND ( ISNULL(MAXCOUNT,0)>=ISNULL(@COUNT,0)))  
  17.   OR(ISNULL(@COUNT,0)>ISNULL(MAXCOUNT,0)))  
  18.   SET @RATE=ISNULL(@QXS*@G,0)  
  19.   RETURN (@RATE)  
  20.   END 

   调用函数的存储过程部分:

 
 
 
  1.  CREATE PROC PROC_FAULTRATE  
  2.   @PARTID INTEGER, @QUALITYID INTEGER,@SOURCEID INTEGER,  
  3.   @COUNT INTEGER, @ROID INT, @GRADE INT,@RATE FLOAT=0 OUTPUTAS  
  4.   BEGIN 
  5.   DECLARE 
  6.   @TASKID INT 
  7.   SET @RATE=0.0  
  8.   SELECT @TASKID=ISNULL(TASKPROID,-1) FROM TABLERELATION  
  9.   WHERE ID=(SELECT PID FROM TABLERELATION WHERE ID=@ROID)  
  10.   IF (@TASKID=-1) OR(@GRADE=1) BEGIN 
  11.   SET @RATE=0  
  12.   RETURN 
  13.   END 
  14.   SELECT @RATE=SUM([DBO].[FUN_RATE]  
  15.   (@PARTID,ENID,@SOURCEID, @QUALITYID,@COUNT) *ISNULL(WORKPERCENT,0)/100.0)  
  16.   FROM TABLETASKPHASE  
  17.   WHERE TASKID=@TASKID  
  18.   END 
  19.   GO  

 本文就为大家总结出了这两种SQL Server数据库函数使用方法,如果大家有更多更好的方法,欢迎拿出来与大家一起分享。

标题名称:讲解SQLServer数据库中函数的使用方法
当前路径:http://www.shufengxianlan.com/qtweb/news26/259876.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联