sqlserver 計算同比,環比增長


/****** Script for SelectTopNRows command from SSMS  ******/
SELECT  [fdSequenceID]
      ,[fdInnerTime]
      ,[fdTime]
      ,[fdData]
      ,[fdState]
      ,[fdUpdateTime]
      ,[fdCreateTime]
  FROM [NewDBTest].[dbo].[tbDataMonthHG]
  


WITH f AS 
(
  SELECT ROW_NUMBER()OVER(   partition by fdSequenceID ORDER BY fdTime) AS id, * FROM [NewDBTest].[dbo].[tbDataMonthHG]
)

select t.*,
       fdRate=(cast(cast(100*((t.fdData/NULLif(d.fdData,0))-1) as numeric(25,10)) as  varchar(50))+'%' )   --小數變百分數
       from f t
left join f d on
       t.fdInnerTime = DateAdd(year,1,d.fdInnerTime) and t.fdSequenceID = d.fdSequenceID  --同比增長
       order by fdSequenceID,id asc 
       

 

環比增長:

WITH f AS 
(
  SELECT ROW_NUMBER()OVER(   partition by fdSequenceID ORDER BY fdTime) AS id, * FROM [NewDBTest].[dbo].[tbDataMonthHG] where fdSequenceID <100
)
 
select t.*,
       fdRate=(cast(cast(100*((t.fdData/NULLif(d.fdData,0))-1) as numeric(25,10)) as  varchar(50))+'%' )   --將分數變為百分數
       from f t
       
left join f d on
       t.fdInnerTime = DateAdd(month,1,d.fdInnerTime) and t.fdSequenceID = d.fdSequenceID   --獲取根據時間獲取上月時間
       order by fdSequenceID,id asc 

 某一時間點與相鄰的上一個時間的增長

 

WITH f AS 
(
  SELECT ROW_NUMBER()OVER(   partition by fdSequenceID ORDER BY fdTime) AS id, * FROM [NewDBTest].[dbo].[tbData]
)
SELECT  
  t.fdSequenceID,t.fdInnerTime,t.fdTime,t.fdData,t.fdState,t.fdUpdateTime,t.fdCreateTime,t.id,
  (select cast(cast(100*((t.fdData/NULLif(d.fdData,0))-1) as numeric(35,10)) as  varchar(50))+'%') AS fdRate
  from f t 
  LEFT JOIN f d on t.id=d.id+1 where t.fdSequenceID = d.fdSequenceID  ORDER by t.fdSequenceID ASC 
  

-- 不會返回null



WITH f AS 
(
  SELECT ROW_NUMBER()OVER(   partition by fdSequenceID ORDER BY fdTime) AS id, * FROM [NewDBTest].[dbo].[tbData] where fdSequenceID<188
)

select t.*,
       cast(cast(100*((t.fdData/NULLif(d.fdData,0))-1) as numeric(25,10)) as  varchar(50))+'%' 
       from f t
left join f d
       on datediff(day, 
                   DateAdd(day,d.id-1,DateAdd(month,d.fdSequenceID-1,'1900-1-1')),
                   DateAdd(day,t.id-1,DateAdd(month,t.fdSequenceID-1,'1900-1-1'))
                   ) > 0

-- 會返回null

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM