Jeśli chcesz uzyskać ostatnie, a następnie poprzednie i tak dalej, musisz użyć funkcji rankingu:
SELECT *
FROM (
SELECT
Users.*,
CASE WHEN @lst=User THEN @row:[email protected]+1 ELSE @row:=0 END row,
@lst:=User
FROM
Users
WHERE
User IN ('ina','chris','john')
ORDER BY
User, Date_ins DESC
) s
WHERE
row=0
row=0 otrzyma ostatnią datę, row=1 poprzednią ostatnią i tak dalej...
Zobacz skrzypce tutaj .