Solved

% change between rows

Posted on 2002-04-12
6
245 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:ScottPletcher
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
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.

 
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

PRTG Network Monitor: Intuitive Network Monitoring

Network Monitoring is essential to ensure that computer systems and network devices are running. Use PRTG to monitor LANs, servers, websites, applications and devices, bandwidth, virtual environments, remote systems, IoT, and many more. PRTG is easy to set up & use.

Question has a verified solution.

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

When you hear the word proxy, you may become apprehensive. This article will help you to understand Proxy and when it is useful. Let's talk Proxy for SQL Server. (Not in terms of Internet access.) Typically, you'll run into this type of problem w…
I have a large data set and a SSIS package. How can I load this file in multi threading?
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…
Via a live example, show how to set up a backup for SQL Server using a Maintenance Plan and how to schedule the job into SQL Server Agent.

919 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

21 Experts available now in Live!

Get 1:1 Help Now