根据参数创建重复的序列号?

问题描述

我实际上是在尝试根据发票屏幕中的参数和发票编号为 SAP Business one 中的发票创建一个唯一的条形码。

例如,我将拥有的固定数据是带有名为“项目数”的参数的“发票编号”

如果参数为 10,我希望 sql 查询返回...

123456 001 010
123456 002 010
123456 003 010
123456 004 010
123456 005 010

等等。这基本上会为我创建 10 个唯一的数字,然后我可以将其用于此发票的一系列条形码? 不需要插入到表中,只需要能够计算出中间的动态值即可。

我将查询的值是

OINV.InvoiceNumber,OINV.NumberOfParcels FROM OINV

非常感谢

安迪

解决方法

如果你有一个数字表,你可以简单地这样做:

DECLARE @SomeNumber INT = 123456,@N          INT = 10;

SELECT
  SomeNumber = @SomeNumber,Col1       = STUFF('000',3+1-LEN(t.N),LEN(t.N),t.N),Col2       = STUFF('000',3+1-LEN(@N),LEN(@N),@N)
FROM  Numbers AS t
WHERE t.N <= @N;

如果不这样做,您可以使用 fnTally。代码如下所示:

SELECT 
  SomeNumber = @SomeNumber,@N)
FROM   dbo.fnTally(1,@N) AS t;

两个查询都返回:

SomeNumber  Col1    Col2    
----------- ------- ------- 
123456      001     010     
123456      002     010     
123456      003     010     
123456      004     010     
123456      005     010     
123456      006     010     
123456      007     010     
123456      008     010     
123456      009     010     
123456      010     010