T-SQL usando SUM para un total acumulado
Tengo una tabla simple con alguna configuración de datos ficticios como:
|id|user|value|
---------------
1 John 2
2 Ted 1
3 John 4
4 Ted 2
Puedo seleccionar un total acumulado ejecutando la siguiente declaración de SQL (MSSQL 2008):
SELECT a.id, a.user, a.value, SUM(b.value) AS total
FROM table a INNER JOIN table b
ON a.id >= b.id
AND a.user = b.user
GROUP BY a.id, a.user, a.value
ORDER BY a.id
Esto me dará resultados como:
|id|user|value|total|
---------------------
1 John 2 2
3 John 4 6
2 Ted 1 1
4 Ted 2 3
¿Ahora es posible recuperar solo las filas más recientes para cada usuario? Entonces el resultado sería:
|id|user|value|total|
---------------------
3 John 4 6
4 Ted 2 3
¿Voy a hacer esto de la manera correcta? ¡Cualquier sugerencia o un nuevo camino a seguir sería genial!