Calculate percent increase/decrease from previous row value

后端 未结 5 1031
再見小時候
再見小時候 2021-01-06 16:57

I have a table that looks something like this:

|date_start  | date_end    |amount | 
+------------+-------------+-------+
|2015-02-23  | 2015-03-01  |50              


        
相关标签:
5条回答
  • 2021-01-06 17:28

    You case use the mysql var system :

    SELECT date_start, date_end, IF(@last IS NOT NULL,ammount - @last , '' ) as perc_change, @last := amount as amount 
    From table 
    ORDER BY date_start; 
    

    the var @last is set at each passage, so column order between perc_change and amount is important

    0 讨论(0)
  • 2021-01-06 17:30

    I started by joining each row in the table with the one that comes after it, like this:

    SELECT m.date_start AS mStart, mt.date_start AS mtStart
    FROM myTable m
    JOIN myTable mT ON m.date_start < mt.date_start AND mt.date_start = (SELECT MIN(date_start) FROM myTable WHERE date_start > m.date_start);
    

    This will join the tables so that each row can be seen with the following date if there is one. If there's not, the date is not returned.

    Once you have those values, you can adjust the SELECT query to show you the percent change from the date before, like this:

    SELECT 
      mT.date_start AS secondDate, 
      mT.amount - m.amount AS percentChange
    FROM myTable m
    JOIN myTable mT ON m.date_start < mT.date_start AND mt.date_start = (SELECT MIN(date_start) FROM myTable WHERE date_start > m.date_start);
    

    I would like to make a note here that while you say 'percent difference' in your question, your expected results have nothing to do with percentage, but just difference in value. If you need to calculate this a different way, you can just adjust the select query above to meet your needs.

    The last thing you will have to do is join this back to your original table to see all of the values together. This has to be done using a left join, in order for the first date of the table to be seen. Here is the final query:

    SELECT m.date_start, m.date_end, m.amount, tmp.percentChange
    FROM myTable m
    LEFT JOIN(
      SELECT 
        mT.date_start AS secondDate, 
        mT.amount - m.amount AS percentChange
      FROM myTable m
      JOIN myTable mT ON m.date_start < mT.date_start AND mt.date_start = (SELECT MIN(date_start) FROM myTable WHERE date_start > m.date_start)
    ) tmp ON tmp.secondDate = m.date_start;
    

    And here is an SQL Fiddle example.

    0 讨论(0)
  • 2021-01-06 17:37

    Try this:

     SELECT t.*,
     amount - (SELECT amount FROM transactions prev WHERE prev.date_end     < t.date_start ORDER BY date_start DESC LIMIT 1) AS changes
     FROM   transactions t
    
    0 讨论(0)
  • 2021-01-06 17:49

    It looks something like this, i dont have environment to test this select but i think it should work

        SELECT t1.date_start, t1.date_end, t1.amount, (t1.amount - t2.amount)  as  perc_change
        FROM table1 t1 
          JOIN table1 t2  ON t1.id = t2.id + 1 // here your join to 
       //get next row and calculate this perc_change field
    
    0 讨论(0)
  • 2021-01-06 17:52

    If we assume that the previous row always ends exactly one day before the current begins (as in your sample data), then you can use a join. The percentage increase would be:

    select t.*,
           100 * (t.amount - tprev.amount) / tprev.amount
    from atable t left join
         atable tprev
         on tprev.date_end = t.date_start - interval 1 day;
    

    However, your results seem to just have the difference, which is easier to calculate:

    select t.*,
           (t.amount - tprev.amount) as diff
    from atable t left join
         atable tprev
         on tprev.date_end = t.date_start - interval 1 day;
    
    0 讨论(0)
提交回复
热议问题