4

我正在使用 MSSQL EXPRESS 2008,我正在尝试使用以下查询将记录的 ID 列与其描述列连接起来

SELECT CAST(GotoviProizvodi.ID as nvarchar(4)) + ' - ' + CAST(GotoviProizvodi.Opis as nvarchar(max)) AS Opis 
FROM GotoviProizvodi,Recept 
WHERE Recept.ID=@ID 
  AND Recept.Proizvod=GotoviProizvodi.Opis

GotoviProizvodi.ID is defined in the schema as int   -- the ID column
GotoviProizvodi.Opis is defined as nvarchar(200)   -- the description column

但是,当我尝试执行查询时,它会产生以下结果:

消息 245,级别 16,状态 1,过程 GetProizvodByReceptId,第 2 行将 nvarchar 值“Test”转换为数据类型 int 时转换失败。

当我明确告诉它将其转换为 nvarchar 时,它为什么要尝试将其转换为 int?任何解决方法?

4

2 回答 2

5

您确定错误与演员阵容有关,而不是与 where 条件有关吗?检查列类型是否匹配

于 2012-11-15T12:00:13.843 回答
4

我想这会做:

SELECT (CONVERT(NVARCHAR, GotoviProizvodi.ID) + ' - ' + GotoviProizvodi.Opis) AS Opis 
FROM GotoviProizvodi,Recept 
WHERE Recept.ID=@ID 
  AND Recept.Proizvod=GotoviProizvodi.Opis
于 2012-11-15T14:32:25.327 回答