微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

串联在SQL Server中用带零的数字中断数字

如何解决串联在SQL Server中用带零的数字中断数字

我有一些无法工作的代码来连接两个字符串,其中一个是年份值,另一个是月份值,我都将其从整数转换为字符串。该月还需要用前导零填充(一月是01,而不是1)。

因此,这是一个年月字段,应阅读此内容以反映2020年1月:

202001

我可以使用以下方法将月份填充到两位数:

LEFT('00'+CAST(a.[Fiscal Month] as varchar(2)),2)) as [YearPeriod]

这是独立的。但是一旦我将其与年份连接起来,就像这样,

CAST(a.[Fiscal Year] as varchar(4)) + LEFT('00'+CAST(a.[Fiscal Month] as varchar(2)),2) as [Period]

然后我结束了一个月。所有日期看起来像这样:

202000

在这里做错了什么?我已经使用了多种语法(与+相对的“ concat”函数,以及在填充与首先转换后转换为字符串)。我还尝试仅用1位数的零填充,以为我用零切断了月份数。

我一直在格式化日期字段并进行处理,因此我无法继续进行需要完成的项目。级联是否以某种方式取消了月份字段?

要输入的字段是nvarchar(6),因此在我的代码中,我将年部分格式化为nvarchar(4),将月部分格式化为nvarchar(2),希望可以将它们一起添加。还有其他想法吗?

解决方法

我认为这可以满足您的需求

convert(varchar(6),a.[Fiscal Year] * 100 + a.[Fiscal Month])

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。