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!

Respuestas a la pregunta(5)

Su respuesta a la pregunta