ALTER PROCEDURE [dbo].[GetbmProduct] @tablename nvarchar(250),@bmzd nvarchar(250),
@bmstr nvarchar(250),@idstr nvarchar(20)
As
declare @maxnumber nvarchar(50)
declare @tabelname1 nvarchar(50)
declare @bmzd1 nvarchar(50)
declare @bmstr1 nvarchar(50)
declare @sqlstr nvarchar(500)
declare @ParmDefinition nvarchar(200)
declare @idstr1 nvarchar(20)
declare @sparam varchar(100)
declare @TODAY char(8)
select @TODAY=''---right(convert(char(8),getdate(),112),6)
set @maxnumber = 0
set @tabelname1 = @tablename
set @bmzd1 = @bmzd
set @bmstr1=@bmstr
set @idstr1=@idstr
set @sparam = @bmstr1 + replace(@idstr1, '0', '[0-9]')
set @sqlstr = N'select Top 1 @maxd='+@bmzd1+' from '+@tabelname1+' where '+@bmzd1+' like '''+@sparam+''' and len('+@bmzd1+')=len('''+@bmstr1+''')+len('''+@idstr1+''') order by '+@bmzd1+' desc'
SET @ParmDefinition = N'@maxd nvarchar(250) output'
EXECUTE sp_executesql @sqlstr, @ParmDefinition,@maxd =@maxnumber output
if @maxnumber is null or left(@maxnumber,(len(@bmstr)))<>@bmstr
begin
select @maxnumber=@bmstr+@idstr1--'000000'
end
select @maxnumber=left(@maxnumber,(len(@bmstr)))+ right(@idstr1 + ltrim(convert(char(20),convert(int,right(@maxnumber,len(@idstr1))))+1),len(@idstr1))
select number=@maxnumber
@bmstr nvarchar(250),@idstr nvarchar(20)
As
declare @maxnumber nvarchar(50)
declare @tabelname1 nvarchar(50)
declare @bmzd1 nvarchar(50)
declare @bmstr1 nvarchar(50)
declare @sqlstr nvarchar(500)
declare @ParmDefinition nvarchar(200)
declare @idstr1 nvarchar(20)
declare @sparam varchar(100)
declare @TODAY char(8)
select @TODAY=''---right(convert(char(8),getdate(),112),6)
set @maxnumber = 0
set @tabelname1 = @tablename
set @bmzd1 = @bmzd
set @bmstr1=@bmstr
set @idstr1=@idstr
set @sparam = @bmstr1 + replace(@idstr1, '0', '[0-9]')
set @sqlstr = N'select Top 1 @maxd='+@bmzd1+' from '+@tabelname1+' where '+@bmzd1+' like '''+@sparam+''' and len('+@bmzd1+')=len('''+@bmstr1+''')+len('''+@idstr1+''') order by '+@bmzd1+' desc'
SET @ParmDefinition = N'@maxd nvarchar(250) output'
EXECUTE sp_executesql @sqlstr, @ParmDefinition,@maxd =@maxnumber output
if @maxnumber is null or left(@maxnumber,(len(@bmstr)))<>@bmstr
begin
select @maxnumber=@bmstr+@idstr1--'000000'
end
select @maxnumber=left(@maxnumber,(len(@bmstr)))+ right(@idstr1 + ltrim(convert(char(20),convert(int,right(@maxnumber,len(@idstr1))))+1),len(@idstr1))
select number=@maxnumber