从上月价格变动表中获取最近2次更新的单价

ct2axkht  于 2021-06-23  发布在  Mysql
关注(0)|答案(2)|浏览(281)

我有一个表格,记录了每种成本价、单价和特价商品的所有价格变化。该表记录数据,即使其中一个定价与旧定价不同。表格结构示例如下所示。

id | item_id | cost_price  | unit_price   | special_price | created_date
---------------------------------------------------------------------------
  1 |   101   |    100      |  NULL        |   NULL        | 2018-07-15 10:02:20
  2 |   102   |   NULL      |  250         |   NULL        | 2018-07-16 12:23:00
  3 |   101   |   NULL      |  150         |   NULL        | 2018-07-16 10:02:20
  4 |   101   |   NULL      |  200         |   NULL        | 2018-07-18 12:23:00
  5 |   101   |   NULL      |  201         |   NULL        | 2018-07-22 10:02:20
  6 |   102   |   NULL      |  283         |   NULL        | 2018-07-28 12:23:00

我想从上表(日期为2018年7月13日)得到上个月的以下输出

item_id   |   unit_price   | changed_date
-----------------------------------------
   101    |    201         | 2018-07-22 10:02:20
   101    |    200         | 2018-07-18 12:23:00
   102    |    283         | 2018-07-28 12:23:00

我需要上面的输出,它只显示最后两个变化发生在单价。

5f0d552i

5f0d552i1#

这似乎很复杂:

SELECT t1.item_id,t1.unit_price,t1.created_date AS changed_date
FROM table_name t1 INNER JOIN 
   (
    SELECT a.item_id, a.unit_price, MAX(a.created_date) AS changed_date
    FROM table_name a INNER JOIN 
    (SELECT item_id, unit_price, MAX(created_date) AS changed_date
    FROM table_name GROUP BY item_id, unit_price) b
    ON a.item_id =  b.item_id and a.created_date < b.changed_date
    GROUP BY a.item_id, a.unit_price
   ) t2
   ON t1.item_id = t2.item_id AND t1.created_date >= t2.changed_date
jv2fixgn

jv2fixgn2#

对于每个项目,最多需要最后两个更改。在mysql(v8之前)中,可以使用变量:

select t.*
from (select t.*,
             (@rn := if(@i = item_id, @rn + 1,
                        if(@i := item_id, 1, 1)
                       )
             ) as rn
      from (select t.*
            from t
            order by t.item_id, t.changed_date desc
           ) t cross join
           (select @i := -1, @rn := 0) params
     ) t
where rn <= 2;

相关问题