Solved

% change between rows

Posted on 2002-04-12
6
254 Views
Last Modified: 2006-11-17
I want to get something like the following.

week count % changed
10   100     0
11   200     100%
12   300     50%
13   100     -66.7%
14   500     500%


What's the simplest way to do this?
0
Comment
Question by:gotaquestion
  • 3
  • 2
6 Comments
 
LVL 69

Expert Comment

by:Scott Pletcher
ID: 6937407
Perhaps something like this:

SELECT week, [count],
    (SELECT ISNULL(CAST((currwk.[count] - prevwk.[count]) AS DECIMAL(10,2)) /
            CAST(currwk.[count] AS DECIMAL(10,2)) * 100.00,0) AS '% changed'
     FROM tablename prevwk
     WHERE prevwk.week = currwk.week - 1)
FROM tablename currwk
0
 
LVL 5

Expert Comment

by:spcmnspff
ID: 6937423
This will find the percentage change in records. in a table provided there is a column named week.  Change Column1 to the name of any field in the table other than Week.

SET ARITHABORT OFF
Select [Week], C1 [Count], (C1-C2)/C1 [% Change]
From
     (select T1.[Week], Count(T1.Column1) C1,
         (Select IsNull(Count(T2.Column1) from MyTable T2 Where T2.[Week] = T1.[Week]-1),0) C2
     From MyTable T1
     Group By T1.[Week]) VT


If you don't have a week field, then you can use the datepart function to get the date from a create date:


SET ARITHABORT OFF
Select [Week], C1 [Count], (C1-C2)/C2 [% Change]
From
     (select DatePart(wk,T1.CreateDt) [Week],
         Count(T1.Column1) C1,
         (Select IsNull(Count(T2.Column1)
             from MyTable T2
             Where DatePart(wk,T2.CreateDt) =
                 DatePart(wk,T1.CreateDt)-1),0) C2
      From MyTable T1
      Group By DatePart(wk,T1.CreateDt)-1)) VT


0
 
LVL 5

Expert Comment

by:spcmnspff
ID: 6937435
Minor Change:  Had to divide by C2 rather than C1:

SET ARITHABORT OFF
Select [Week], C1 [Count], (C1-C2)/C2 [% Change]
From
    (select T1.[Week], Count(T1.Column1) C1,
        (Select IsNull(Count(T2.Column1) from MyTable T2 Where T2.[Week] = T1.[Week]-1),0) C2
    From MyTable T1
    Group By T1.[Week]) VT


Or with the datepart function:

SET ARITHABORT OFF
Select [Week], C1 [Count], (C1-C2)/C2 [% Change]
From
    (select DatePart(wk,T1.CreateDt) [Week],
        Count(T1.Column1) C1,
        (Select IsNull(Count(T2.Column1)
            from MyTable T2
            Where DatePart(wk,T2.CreateDt) =
                DatePart(wk,T1.CreateDt)-1),0) C2
     From MyTable T1
     Group By DatePart(wk,T1.CreateDt)-1)) VT
0
U.S. Department of Agriculture and Acronis Access

With the new era of mobile computing, smartphones and tablets, wireless communications and cloud services, the USDA sought to take advantage of a mobilized workforce and the blurring lines between personal and corporate computing resources.

 
LVL 1

Author Comment

by:gotaquestion
ID: 6937507
I've created a table to support your queries and with both the last ones your proposed I'm getting.  

Server: Msg 156, Level 15, State 1, Line 7
Incorrect syntax near the keyword 'from'.

I think it's missing a )

I can't seem to see it.


0
 
LVL 5

Accepted Solution

by:
spcmnspff earned 100 total points
ID: 6937548
Oops.  Fixed it.  I had to change the  postition of my isnull =)  :

SET ARITHABORT OFF
Select [Week], C1 [Count], (C1-C2)/C2 [% Change]
From
   (select T1.[Week], Count(T1.Column1) C1,
       IsNull((Select Count(T2.Column1) from MyTable T2 Where T2.[Week] = T1.[Week]-1),0) C2
   From MyTable T1
   Group By T1.[Week]) VT


Or with the datepart function:

SET ARITHABORT OFF
Select [Week], C1 [Count], (C1-C2)/C2 [% Change]
From
   (select DatePart(wk,T1.CreateDt) [Week],
       Count(T1.Column1) C1,
       IsNull((Select Count(T2.Column1)
           from MyTable T2
           Where DatePart(wk,T2.CreateDt) =
               DatePart(wk,T1.CreateDt)-1),0) C2
    From MyTable T1
    Group By DatePart(wk,T1.CreateDt)) VT
0
 
LVL 1

Author Comment

by:gotaquestion
ID: 6937619
Thanks, I had to fix the divide by zero error because the
SET ARITHIGNORE OFF
SET ARITHABORT OFF
were not working for some reason.

Select [Week], C1 [Count], CASE C2 WHEN 0 THEN 0 ELSE (C1-C2)/C2 END [% Change]
From
  (select T1.[Week], sum(T1.Column1) C1,
      IsNull((Select sum(T2.Column1) from MyTable T2 Where T2.[Week] = T1.[Week]-1),0) C2
  From MyTable T1
  Group By T1.[Week]) VT
0

Featured Post

Best Practices: Disaster Recovery Testing

Besides backup, any IT division should have a disaster recovery plan. You will find a few tips below relating to the development of such a plan and to what issues one should pay special attention in the course of backup planning.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction SQL Server Integration Services can read XML files, that’s known by every BI developer.  (If you didn’t, don’t worry, I’m aiming this article at newcomers as well.) But how far can you go?  When does the XML Source component become …
Load balancing is the method of dividing the total amount of work performed by one computer between two or more computers. Its aim is to get more work done in the same amount of time, ensuring that all the users get served faster.
Familiarize people with the process of utilizing SQL Server functions from within Microsoft Access. Microsoft Access is a very powerful client/server development tool. One of the SQL Server objects that you can interact with from within Microsoft Ac…
Viewers will learn how the fundamental information of how to create a table.

813 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

10 Experts available now in Live!

Get 1:1 Help Now