问题描述
我实际上是在尝试根据发票屏幕中的参数和发票编号为 SAP Business one 中的发票创建一个唯一的条形码。
例如,我将拥有的固定数据是带有名为“项目数”的参数的“发票编号”
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