2014-11-28 18 views
5
+--------+---------+-------+--------+ 
| billID | orderId | price | date | 
+--------+---------+-------+--------+ 
|  1 |  1 | 100 | 1.3.12 | 
|  2 |  1 | 230 | 1.4.12 | 
|  3 |  1 | 300 | 1.5.12 | 
|  4 |  2 | 1000 | 1.3.12 | 
|  5 |  2 | 160 | 1.4.12 | 
|  6 |  3 | 400 | 1.3.12 | 
+--------+---------+-------+--------+ 

Tüm fiyatların aynı sipariş kimliğine sahip olduğu ancak satırların tarihinden önceki tarihlerle aynı olan bir sütun içeren görünüm oluşturmak istiyorum.Önceki fiyattan toplam fiyatı toplamak için bir sütun nasıl seçebilirim?

+--------+---------+-------+--------+--------------+ 
| billID | orderId | price | date | add-on price | 
+--------+---------+-------+--------+--------------+ 
|  |   |  |  |    | 
|  1 |  1 | 100 | 1.3.12 |   100 | 
|  2 |  1 | 230 | 1.4.12 |   330 | 
|  3 |  1 | 300 | 1.5.12 |   630 | 
|  4 |  2 | 1000 | 1.3.12 |   1000 | 
|  5 |  2 | 160 | 1.4.12 |   1160 | 
|  6 |  3 | 400 | 1.3.12 |   400 | 
+--------+---------+-------+--------+--------------+ 

cevap

2

yapabilirsiniz kullanıcı bunun için bağıntılı alt sorgu:

select t.*, 
     (select sum(t2.price) 
     from table t2 
     where t2.orderId = t.orderId and t2.date <= t.date 
     ) as CumulativePrice 
from table t; 
Bunun gibi
İlgili konular