sql >> Databáze >  >> RDS >> Mysql

získat po sobě jdoucí záznamy v mysql

Vnitřní dotaz počítá každý pruh. Vnější dotaz získá maximum na uživatele. Dotaz není testován (ale je založen na jednom, který funguje)

set @user_id = null;
set @streak = 1;

select user_id, max(streak) from (
  SELECT user_id, streak,
    case when @user_id is null OR @user_id != user_id then @streak := 1 else @streak := @streak + 1 end as streak_formula,
    @user_id := user_id,
    @streak as streak
  FROM my_table
) foo
group by user_id


  1. Použití pravidel polí pomocí klasifikace

  2. Brána PL/SQL v R11i

  3. Jak EXCEPT funguje v SQL Server

  4. Co je T-SQL?