Declare @maxVersion int,@strYear varchar(2),@strMonth varchar(2),@strYearMonth varchar(4)
Set @strYear = Right(Cast(Datepart(yy,Getdate()) AS varchar(4)),2)
Set @strMonth = Cast(Datepart(mm,Getdate()) AS varchar(4))
if (Len(@strMonth) = 1)
Set @strMonth = '0' + @strMonth
Set @strYearMonth = @strYear + @strMonth
select @maxVersion = max(BomVersion) from TBL_Bom Where MaterialNo = @MaterialNo
--当最大值无效,或当前月份有大于最大值月份时
if (@maxVersion is null OR @maxVersion = 0 OR Cast(@strYearMonth AS Int) > @maxVersion / 100)
set @BomNewVersion = Cast( (@strYearMonth + '01') AS int)
else
Set @BomNewVersion = @maxVersion + 1
三个SUBSTRING
Sql server 中 SELECT x = SUBSTRING('abcdef', 1,len('abcdef'))
c# 中: string x = SUBSTRING('abcdef', 0,len('abcdef'))
javascript中:string x = SUBSTR('abcdef', 0,len('abcdef'))
稍微有点区别。
Set @strYear = Right(Cast(Datepart(yy,Getdate()) AS varchar(4)),2)
Set @strMonth = Cast(Datepart(mm,Getdate()) AS varchar(4))
if (Len(@strMonth) = 1)
Set @strMonth = '0' + @strMonth
Set @strYearMonth = @strYear + @strMonth
select @maxVersion = max(BomVersion) from TBL_Bom Where MaterialNo = @MaterialNo
--当最大值无效,或当前月份有大于最大值月份时
if (@maxVersion is null OR @maxVersion = 0 OR Cast(@strYearMonth AS Int) > @maxVersion / 100)
set @BomNewVersion = Cast( (@strYearMonth + '01') AS int)
else
Set @BomNewVersion = @maxVersion + 1
三个SUBSTRING
Sql server 中 SELECT x = SUBSTRING('abcdef', 1,len('abcdef'))
c# 中: string x = SUBSTRING('abcdef', 0,len('abcdef'))
javascript中:string x = SUBSTR('abcdef', 0,len('abcdef'))
稍微有点区别。
分类:
database
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架