Exakt vad det står:
'name1'
har en annan datatyp än 'name' + CAST((rn+1) as varchar(255))
Prova detta (otestat)
;with cte as
(
select 1 as rn, CAST('name1' as varchar(259)) as nm
union all
select rn+1,nm = 'name' + CAST((rn+1) as varchar(255))
from cte a where rn<10)
select * from cte
I grund och botten måste du se till att längden matchar också. För den rekursiva biten kan du behöva använda CAST('name' AS varchar(4))
om det misslyckas igen