CTE error: "Types don't match between the anchor and the recursive part" CTE error: "Types don't match between the anchor and the recursive part" sql sql

CTE error: "Types don't match between the anchor and the recursive part"


Exactly what it says:

'name1' has a different data type to 'name' + CAST((rn+1) as varchar(255))

Try this (untested)

;with cte as(select 1 as rn, CAST('name1' as varchar(259)) as nmunion allselect rn+1,nm = 'name' + CAST((rn+1) as varchar(255))from cte a where rn<10)select * from cte

Basically, you have to ensure the length matches too. For the recursive bit, you may have to use CAST('name' AS varchar(4)) if it fails again


You need to cast both nm fields

;with cte as(select  1 as rn,         CAST('name1' AS VARCHAR(255)) as nmunion allselect  rn+1,        nm = CAST('name' + CAST((rn+1) as varchar(255)) AS VARCHAR(255))from cte a where rn<10)select * from cte


For me problem was in different collation.

Only this helped me:

;WITH cte AS (  SELECT     1 AS rn,     CAST('name1' AS NVARCHAR(4000)) COLLATE DATABASE_DEFAULT AS nm  UNION ALL  SELECT     rn + 1,    nm = CAST('name' + CAST((rn + 1) AS NVARCHAR(255)) AS NVARCHAR(4000)) COLLATE DATABASE_DEFAULT  FROM cte a WHERE rn < 10)SELECT * FROM cte;

Hope it can help someone else.