Możesz przenieść inicjalizację zmiennych sesji zdefiniowanych przez użytkownika do tabeli pochodnej i Cross Join
z Twoimi innymi stolikami:
SELECT SUBSTRING_INDEX(@input, ' ', (@count) * 2), ' ', -1) AS xyz,
som_cnt AS `count`
FROM abc
CROSS JOIN (SELECT @count := 0,
@input := '22:4,33:4'
) AS user_init_vars