成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

講解SQL Server數(shù)據(jù)庫中函數(shù)的使用方法

數(shù)據(jù)庫 SQL Server
SQL Server數(shù)據(jù)庫是一種功能性很好的關(guān)系數(shù)據(jù)庫管理系統(tǒng),本文中主要為大家介紹SQL Server數(shù)據(jù)庫中函數(shù)的使用方法。

導(dǎo)讀:本文主要主要講解了SQL Server數(shù)據(jù)庫中函數(shù)的兩種用法,具體內(nèi)容請參考下文:

  1. 由于update里不能用存儲過程,并且由于根據(jù)更新表的某些字段還要進(jìn)行計算。所以很多人采用的是游標(biāo)的方法,在這里我們可以用函數(shù)的方法實(shí)現(xiàn)。

  函數(shù)部分:

  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 

   調(diào)用函數(shù)的存儲過程部分:

  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. 我們要根據(jù)某表的某些記錄,先計算后求和,因為無法存儲中間值,平時我們也用游標(biāo)的方法進(jìn)行計算。但SQL Server 2000里支持。

  SUM ( [ ALL DISTINCT ] eXPression )
  expression

  是常量、列或函數(shù),或者是算術(shù)、按位與字符串等運(yùn)算符的任意組合。因此我們可以利用這一功能。

  函數(shù)部分:

  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=NULLOR (@PARTID=NULLOR (@SOURCEID=NULLOR (@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 

   調(diào)用函數(shù)的存儲過程部分:

  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  


 本文就為大家總結(jié)出了這兩種SQL Server數(shù)據(jù)庫函數(shù)使用方法,如果大家有更多更好的方法,歡迎拿出來與大家一起分享。

【編輯推薦】

  1. SQL Server的函數(shù)庫漏洞
  2. Oracle中over函數(shù)的使用示例
  3. Oracle單行日期函數(shù)簡介
  4. SQL Server數(shù)據(jù)庫中對圖片進(jìn)行保存和輸出
責(zé)任編輯:迎迎 來源: 希賽網(wǎng)
相關(guān)推薦

2011-08-02 14:29:06

SQL Server數(shù)Substring函數(shù)

2011-08-22 10:47:09

SQL Server流水號

2011-07-21 15:05:14

iPhone 數(shù)據(jù)庫

2011-08-22 13:04:47

SQL Server數(shù)函數(shù)

2011-08-22 11:39:53

SQL Server數(shù)PIVOT

2011-08-11 17:00:33

iPhone數(shù)據(jù)庫SQLite

2011-08-30 13:49:57

Qt數(shù)據(jù)庫QTableView

2011-08-25 16:13:31

SQL Server批量替換數(shù)據(jù)

2010-09-06 09:53:41

SQL Server語句

2010-09-14 09:53:52

sql server還

2009-03-19 09:44:07

SQL Server數(shù)據(jù)庫遷移數(shù)據(jù)庫

2011-08-25 17:49:14

MySQLmysqlcheck

2011-08-22 13:28:56

FOR XMLSQL Server

2009-03-30 10:56:58

SQL Server數(shù)據(jù)庫死鎖數(shù)據(jù)庫

2011-03-30 15:36:31

SQL Server

2010-10-20 11:07:21

sql server全

2011-08-10 09:12:44

SQL Server插入圖像存儲過程

2011-08-15 13:48:47

SQL ServerROW_NUMBER(

2011-08-29 14:44:56

DBLINK

2010-07-15 17:28:50

SQL Server
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 久久一区二区三区四区 | 亚洲视频欧美视频 | 精品久久久久久久久久久久 | 免费视频二区 | 久久精品亚洲欧美日韩精品中文字幕 | 在线一区视频 | 国产精品久久久久久一区二区三区 | 91中文字幕在线 | 国产91丝袜在线播放 | 天堂一区二区三区 | 日本精a在线观看 | 久久久www成人免费无遮挡大片 | 国产免费自拍 | 欧美成人激情 | 蜜月va乱码一区二区三区 | 看av网| www.亚洲国产精品 | 国产精品看片 | 国产成人精品网站 | 国产精品久久久久久 | 欧美色欧美亚洲另类七区 | 日韩一区二区成人 | caoporn地址| av免费在线观看网站 | 国产在线观看一区二区 | 欧州一区二区三区 | 久久中文字幕一区 | 久草网址 | 欧美一区二区免费电影 | 成人久久久 | 国产区在线看 | 国产精品亚洲第一 | 欧美中文字幕一区二区三区亚洲 | 亚洲一区在线免费观看 | 日韩精品一区二区三区中文字幕 | 日韩欧美国产精品 | 国产一区二区精华 | 国产精品免费一区二区三区四区 | 99精品欧美一区二区三区 | 在线一区观看 | 中文字幕一区二区三区精彩视频 |