我写了商店程序,它应该返回如下的值:
J1
J2
J3
Run Code Online (Sandbox Code Playgroud)
我有桌子命名Journal_Entry.当表的行数为0时,它会给出结果,J1但随着行数增加,它会显示错误 -
"Conversion failed when converting the varchar value 'J' to data type int."
Run Code Online (Sandbox Code Playgroud)
#here Voucher_No是要保存的结果列.
代码如下 -
CREATE PROC [dbo].[getVoucherNo]
AS
BEGIN
DECLARE @Prefix VARCHAR(10)='J'
DECLARE @startFrom INT=1
DECLARE @maxCode VARCHAR(100)
DECLARE @sCode INT
IF((SELECT COUNT(*) FROM dbo.Journal_Entry) > 0)
BEGIN
SELECT @maxCode = CAST(MAX(CAST(SUBSTRING(Voucher_No,LEN(@startFrom)+1,LEN(Voucher_No)- LEN(@Prefix)) AS INT)) AS varchar(100)) FROM dbo.Journal_Entry;
SET @sCode=CAST(@maxCode AS INT)
SELECT @Prefix + LEN(CAST(@maxCode AS VARCHAR(10))+1) + CAST(@maxCode AS VARCHAR(100))
END
ELSE
BEGIN
SELECT(@Prefix …Run Code Online (Sandbox Code Playgroud)