增加nvarchar和数字的组合

时间:2013-09-02 12:30:22

标签: sql sql-server-2008 tsql

以下场景: 我需要增加像这样的代码DS0000001 因此,下一个项目将是DS0000002,跟随DS0000003,依此类推。

因此,为了在一个大的INSERT语句中生成此代码,我编写了以下函数:

CREATE FUNCTION dbo.eufn_e5_importCRM_getNextClientCode(
  @partnerCode AS NVARCHAR(10),
  @number AS INT
    )
    RETURNS NVARCHAR(20)
    AS
    BEGIN
        DECLARE @next AS INT
        DECLARE @zeroes AS NVARCHAR(10)
        DECLARE @nextStr AS NVARCHAR(10)
        DECLARE @return AS NVARCHAR(20)
        DECLARE @partnerPrefix AS NVARCHAR(10)

        SELECT @next = RIGHT(c.clientCode,7) FROM Clients c

        SELECT @partnerPrefix = partners.partnerPrefix
          FROM partners WHERE partnerCode = @partnerCode
        SET @next = ISNULL(@next,0) + @number   
        SET @nextStr = CONVERT(NVARCHAR(10),@next)

        SELECT @zeroes = CASE WHEN @next > 9 THEN '00000'
                WHEN @next > 99 THEN  '0000'
                WHEN @next > 999 THEN  '000'
                WHEN @next > 9999 THEN  '00'
                WHEN @next > 99999 THEN  '0'
                WHEN @next > 999999 THEN  ''
                ELSE '000000'
        END

        IF ISNULL(@next,'') = ''
        BEGIN
            SET @return = @partnerPrefix + @zeroes + '1'
        END
        ELSE SET @return = @partnerPrefix + @zeroes + @nextStr

        RETURN @return
    END

@number使用ROW_NUMBER() - 函数手动获取我在insert语句中添加的行号。

这已经可以了 - 它将正确的代码插入到表中。

我对这段代码不喜欢的是这部分:

SELECT @zeroes = CASE WHEN @next > 9 THEN '00000'
        WHEN @next > 99 THEN  '0000'
        WHEN @next > 999 THEN  '000'
        WHEN @next > 9999 THEN  '00'
        WHEN @next > 99999 THEN  '0'
        WHEN @next > 999999 THEN  ''
        ELSE '000000'
END

我已经在stackoverflow上搜索了一段时间并且也用谷歌搜索了,但是我找不到像转换那样留下“0”的函数。

任何想法如何使这个功能更灵活,如果可能的话:可重用?

提前感谢您的帮助!

1 个答案:

答案 0 :(得分:1)

这是你可以这样做的

Declare @a int
Set @a =8756
Select 'DS' + REPLACE(STR(@a, 7), SPACE(1), '0')

演示:http://sqlfiddle.com/#!3/d41d8