- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以在我的数据库中,我得到了表格
Product (prodId,Name,Price)
Box (BoxId,prodId,From,To,Available)
'From
'代表第一个序号。和“To
”结尾的连续剧。计算“To
”子“From
”给出产品
的数量。
一位客户来了并订购了给定数量的给定产品。我需要的是“发件人”序列号,我计算“发件人”+数量。如果序列号只是连续的整数。这很容易。但这适用于具有不同序列号的所有类型的产品。例如:
Box( 1,1,ABC00000C,ABC00099K,100)
我想要实现的是:
SELECT From + 50 FROM BOX
如何处理序列号以获得订单结束序列号?
最佳答案
要处理此类序列号,您需要(选项 1)fn(x) 计算给定整数 x 的序列号,或(选项 2)可用序列号列表。
方案一最容易实现,但它需要想出序号格式的人确实也想过编一个转换公式把整数转换成序号。如果存在这样的公式,您需要做的就是确定“from”值的整数值,将此整数值“x”加 50 并确定“x + 50”的序列号。
选项 2 要求您有一个列表,或者可以生成一个序列号列表,而且这些序列号必须(以某种方式)按逻辑顺序排列。选项 2 然后应用 SQL Server 提供的多种方法之一从该列表中获取接下来的 50 行,从其中值为“From”的行开始。这种方法的例子是“select top (50) ...”,窗口函数“row_number() over (order by ...)”,“select ... order by ... offset n rows fetch next 50 rows only "甚至是光标。
在 Wildfire 发表评论后添加:
我建议您创建一个表来保存选项 2 的序列号。让我举一个例子来解释这一点:如果一个序列号为 n + 5 的项目碰巧从生产线上掉下来并且损坏得无法修复,您会怎么做? IE。这个序列号永远不会运送给客户。我敢打赌,当发生这种情况时,您不会运送一箱少一件的元素,也不会因为一件元素丢失而丢弃 49 件未损坏的产品。相反,您可能会将序列号为 n 到 n + 4 和序列号为 n + 6 到 n + 51 的所有产品放在一个盒子里,而将序列号 n + 5 留在外面。在一个完美的世界中,这当然永远不会发生,但在现实生活中,有时确实会出问题,因此您需要能够应对 - 例如 - 丢失连续剧。所以我真的建议创建一个表,其中包含所有可用于装箱的连续剧,然后让您的装箱过程从该表中读取接下来的 50 个连续剧。
并且选项 1 可以工作,即使序列本身是非数值但可以计算成数值。只是有点复杂。这就是为什么我说连续剧必须存在一个公式才能使该方法起作用。这是一个示例,您可以如何将 50 添加到序列号“ABC00000C”,从而使“ABC00001Y”成为序列号:
declare @from varchar(9) = 'ABC00000C';
declare @from_int bigint;
with cteSerialCharacters as (
-- The set of characters used in a serial.
-- As an example I've taken all number characters plus
-- all capital letters from the alphabet excluding any
-- of these that are easily misread.
select '0123456789ABCDEFGHJKLMNPRSTVWXYZ' as chars
),
cteNumberGenerator as (
select cast (row_number() over (order by (select null)) as bigint) as n
from ( select 1 union all select 1 union all select 1 union all select 1
union all select 1 union all select 1 union all select 1
union all select 1 union all select 1
) t (xyz)
)
select
@from_int = sum(power(s.base, (n - 1)) * (-1 + charindex(substring(reverse(s.serial), n.n, 1), s.characterset)))
from (
select
@from,
cast(len(ch.chars) as bigint),
ch.chars
from cteSerialCharacters ch
) s (serial, base, characterset)
inner join cteNumberGenerator n on (n.n <= len(s.serial));
select @from, @from_int;
declare @to varchar(9);
declare @to_int bigint;
select @to_int = @from_int + 50;
with cteSerialCharacters as (
-- The set of characters used in a serial.
-- As an example I've taken all number characters plus
-- all capital letters from the alphabet excluding any
-- of these that are easily misread.
select '0123456789ABCDEFGHJKLMNPRSTVWXYZ' as chars
),
cteNumberGenerator as (
select cast (row_number() over (order by (select null)) as bigint) as n
from ( select 1 union all select 1 union all select 1 union all select 1
union all select 1 union all select 1 union all select 1
union all select 1 union all select 1
) t (xyz)
)
select
@to = (
select
substring(s.characterset, 1 + (@to_int / power(s.base, n.n - 1)) % s.base, 1) as [text()]
from (
select
cast(len(ch.chars) as bigint),
ch.chars
from cteSerialCharacters ch
) s (base, characterset)
cross join cteNumberGenerator n
order by n.n desc
for xml path(''), type
).value('text()[1]', 'varchar(9)')
select @to, @to_int;
关于mysql - 产品 alpha-num 序列号的数学运算 |数据库设计,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46685595/
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我不知道我问的是否可行。 我有一个带有 Color.BLACK 的 Paint 和 0.2f 的 alpha 和两个对象: 它们都使用相同的Paint。我还测试了 2 个不同的 Paint 对象,仅更
Alpha Vantage API 不提供纳斯达克指数的报价(不再?)。我感兴趣的所有其他 indizes 似乎都很有魅力。 例如,调用以下 URL(隐藏 API key )将提供 S&P 的报价(符
问:有没有办法使用默认管道正确混合 Alpha 分量? 问题:我正在将半透明表面绘制到纹理中,然后我想将该纹理传输到主框架后台缓冲区中。通常,当您使用直接的 Alpha 混合来实现透明度或抗锯齿时,会
如果我有一个底层颜色和一个 alpha 值 (C&A),并且想在屏幕上创建一个自定义 C&A,那么确定必须将什么 C&A 作为底层添加到底层之上的层的函数是什么? 编辑: 我想复制 photoshop
我想知道它们之间的区别: 给我的 UIView 分配一个颜色 <1 alpha vs 为它指定一个不透明的颜色,但给 UIView 一个 <1 的 alpha 值。 在屏幕截图上,我制作了两个 UIV
我在 OSX 10.9.4 上试图转换这个 python 正则表达式 p = "(2024 (?:(?:(?:[a-z|.]+ ?)+)) 93)"到 Unix 正则表达式以提高 grep 的速度。
我为 4 张图像制作了这个脚本,第一张图像是 alpha,但从第二张开始什么都没有显示 这是ffmpeg的代码确实有错误,但我没有。不明白:[swscaler @ 0x7fef79845e00] 使用
我正在尝试将文本绘制到具有特定 Alpha 级别的 Canvas 上,并剪辑文本并使用其自己的 Alpha 级别绘制背景颜色: ctx.globalCompositeOperation = '...'
我需要实现Lasso和Ridge回归,并通过交叉验证的方式计算超参数。我找到了执行此操作的代码,但我不太理解它。 lassocv = LassoCV(alphas=None, cv=15, max_i
我得到我的位图,将它用作着色器平铺模式。 除了要绘制的形状轮廓外,PNG 大部分是 alpha。 除了它画出轮廓,但被黑色包围,不是透明的(alpha)。 pnt.reset(); i
我正在开发一个带有 tableViewController 的应用程序。我想在我的表格 View 单元格下方添加背景图片。我想让表格 View 单元格透明,以便我的整个表格 View 可以具有自定义背
如图所示,我有 2 个具有 0.5 alpha 和 1 alpha 的按钮。我想将第一张图片中标题的 alpha 更改为 1,这可能吗? 到目前为止,我尝试了这些都不起作用: button.title
我正在尝试生成一个 python 正则表达式来表示词法分析器的标识符。我的做法是: ([a-zA-Z]([a-zA-Z]|\d)*) 当我使用它时: regex = re.compile("\s*([
我正在尝试删除所有非数字字符的字符串,并且我已阅读 Why isn't isnumeric working? ,或者我必须有一个 unicode 字符串。然而,自从 is.alnum()和is.alp
来自 hadoop 网站上的发布页面: “This release, like previous releases in hadoop-2.x series is still considered a
真的没有与 setAlpha(int) 对应的 XML 属性吗? 如果没有,有什么替代方案? 最佳答案 它比其他响应更容易。有一个 xml 值 alpha 采用 double 值。 android:a
我正在three.js 中构建一个“ Papercut ”世界。我所有的模型都是简单的“平面”,我使用带有 Alpha channel 的 PNG 对它们进行纹理处理,以将平面修剪成更令人愉悦的形状。
我想知道 Graphics2D.setComposite(..., alpha) 之间是否真的有区别和 Graphics2D.setColor(new Color(..., alpha))在 Java
我需要在两个图像之间进行转换 - 两个图像都是隐藏下面的 Sprite 的蒙版。每个面具的一部分是白色的,一部分是透明的。我需要两个图像的总 alpha 每次都为 1,这样蒙版看起来会平滑地改变其形状
我是一名优秀的程序员,十分优秀!