Pour utiliser des variables pour représenter des colonnes (ou des tables), vous devez utiliser PREPARE/EXECUTE. Essayez quelque chose comme ceci :
SET @colindex1=(CONCAT(i, @indent);
SET @stmt = 'SELECT @colindex1 FROM tableindex WHERE main=19';
PREPARE thestmt FROM @stmt;
EXECUTE thestmt;