首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用'+‘符号连接时出现错误"Conversion failed when the varchar value 'current quarter’to data type int.“

使用'+‘符号连接时出现错误"Conversion failed when the varchar value 'current quarter’to data type int.“
EN

Stack Overflow用户
提问于 2016-09-28 01:54:46
回答 1查看 337关注 0票数 0

我正在尝试使用+符号连接几个字符串...当我使用concat函数时,它工作得很好,但当我使用'+‘符号来连接字符串时,它抛出了一个错误。

有人知道为什么会发生这个问题吗?下面是使用concat的代码,运行良好

代码语言:javascript
复制
    Begin
    DECLARE @VAR1 AS VARCHAR(60)
    SET @VAR1 = concat ((SELECT MIN(TimeDimension_Year) FROM TimeDimension_LU WHERE TimeDimension_TimeDimensionType_ID = 15), '-','current quarter')
    SELECT @VAR1
    end

下面是使用'+‘符号的相同代码,但失败了

代码语言:javascript
复制
    Begin
    DECLARE @VAR1 AS VARCHAR(60)
    SET @VAR1 = (SELECT MIN(TimeDimension_Year) FROM TimeDimension_LU WHERE TimeDimension_TimeDimensionType_ID = 15)+ '-'+'current quarter'
    SELECT @VAR1
    end
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-09-28 02:02:58

显然,某些东西不是字符串。这将是TimeDimension_Year列。所以:

代码语言:javascript
复制
SET @VAR1 = (SELECT CAST(MIN(TimeDimension_Year) as varchar(255))
             FROM TimeDimension_LU
             WHERE TimeDimension_TimeDimensionType_ID = 15
            ) + '-' + 'current quarter';

这对我的口味来说有点冗长。我只会说:

代码语言:javascript
复制
SELECT @VAR1 = CAST(MIN(TimeDimension_Year) as varchar(255)) + '-' + 'current quarter'
FROM TimeDimension_LU
WHERE TimeDimension_TimeDimensionType_ID = 15;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39731310

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档