select name,
@rownum := @rownum + 1 as row_number
from your_table
cross join (select @rownum := 0) r
order by name
Tato část:
cross join (select @rownum := 0) r
umožňuje zavést proměnnou bez nutnosti samostatného dotazu. První dotaz by tedy mohl být také rozdělen na dva dotazy takto:
set @rownum := 0;
select name,
@rownum := @rownum + 1 as row_number
from your_table
order by name;
například při použití v uložené proceduře.