SQL Server存储过程 - 返回包含字母数字结果的3个字符行号的逻辑

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL Server存储过程 - 返回包含字母数字结果的3个字符行号的逻辑相关的知识,希望对你有一定的参考价值。

OPEN abcTables
    FETCH NEXT FROM abcTables INTO @TableName
    WHILE @@FETCH_STATUS = 0 

    BEGIN
        SET @SQLTableName = (SELECT CHAR(39) + @TableName + CHAR(39))
        SET @LineNum      = CHAR(39) + dbo.[GetabcLine](@TableName) + CHAR(39)
        /*                = (SELECT CHAR (39)+ CASE WHEN REPLACE(RIGHT(@TableName, 2), 'e', '0') = '00'
                                                    THEN '0' 
                                                    ELSE REPLACE(RIGHT(@TableName, 2), 'e', '0')
                                               END
                                                 + CHAR(39))
        */ Requires more sophisticated logic to return 3 char line numbers that includes alphanumeric results
        SET @SQLCmd       = 'UPDATE ' + @TableName + ' ' + '    
                                SET [Job#] = jobs.[mode#]
                                  , [Line] = ' + @LineNum + '
                                  , [StartofJob] = jobs.[start date] 
                                  , [EndofJob] = CASE WHEN jobs.[end date] = GETDATE() THEN NULL ELSE jobs.[end date] END
                                  , [ModelID] = CASE WHEN [ModelID] IS NULL THEN ' + @dent + ' 
                                                     WHEN [ModelID] = ' + @Tnie + ' THEN ' + @ari + ' 
                                                     ELSE [ModelID]
                                                END
                             FROM ' + @TableName + ' hrb ' + '
                             INNER JOIN #Jobs jobs ON hrb.Time1 BETWEEN jobs.[start date] AND jobs.[end date] ' + '
                             WHERE jobs.[line] = ' + @LineNum + ' ' + '
                             AND [Time1] >= DATEADD(DAY,-90, GETDATE())'

EXEC (@SQLCmd)

FETCH NEXT FROM abcTables INTO @TableName

END 

CLOSE abcTables
DEALLOCATE abcTables

DROP TABLE #Jobs

结束

将生产计算机值从一个数据库返回到另一个数据库的另一个sql server的存储过程。目前它已经添加了仅包含两个字符但新生产线的数据,并添加了一个用于识别包含字母数字的3字符行号的附加内容。有什么建议?

答案

听起来您想要将您的功能修改为3个字符后缀的新更改并匹配您的作业表。

dbo.[GetabcLine](@TableName) --==>
SET @LineNum = CASE WHEN REPLACE(RIGHT(@TableName, 3), 'e', '0') = '00'
                                                    THEN '0' 
                                                    ELSE REPLACE(RIGHT(@TableName, 3), 'e', '0')
                                               END

我在我的在线SQL游乐场中包含了您的脚本:https://sqleditor.net/q/BJpRYsHuM

您可以保存您的版本并向我显示有关您的问题的更多详细信息。

以上是关于SQL Server存储过程 - 返回包含字母数字结果的3个字符行号的逻辑的主要内容,如果未能解决你的问题,请参考以下文章

sql server远程调用失败怎么解决

SQL Server 2019 (Mac) Notes

sql server 中 一个要输入参数和输出参数的存储过程。

SQL SERVER存储过程一

SQL Server 数据库的维护(上)_存储过程(procedure)

通过 ASP.NET Core Web API 使用存储过程从 SQL Server 返回多个行集