Puoi spostare l'inizializzazione delle variabili di sessione definite dall'utente in una tabella derivata e Cross Join
con gli altri tuoi tavoli:
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