- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在为一个项目编写一些 SQL,我注意到 SQL Server 中有一些看似奇怪的行为,关于除以小数时答案的样子。
这里有一些例子可以说明我所看到的行为:
DECLARE @Ratio Decimal(38,16)
SET @Ratio = CAST(210 as Decimal(38,16))/CAST(222 as Decimal(38,16));
select @Ratio -- Results in 0.9459450000000000
DECLARE @Ratio Decimal(38,16)
SET @Ratio = CAST(210 as Decimal)/CAST(222 as Decimal);
select @Ratio -- Results in 0.9459459459459459
对于上面的代码,(看似)不太精确的查询答案给出了更精确的值作为答案。当我将被除数和除数都转换为 Decimal(38,16)
时,我得到一个标度为 6 的数字(将其转换为 Decimal(38,16)
> 再次导致 0 填充比例)。
当我将被除数和除数转换为默认小数时,没有手动设置精度或比例,我得到了结果比例中的完整 16 位数字。
出于好奇,我开始使用这些查询对其进行更多试验:
select CAST(210 as Decimal(38,16))/CAST(222 as Decimal(38,16)) --0.945945
select CAST(210 as Decimal(28,16))/CAST(222 as Decimal(28,16)) --0.9459459459
select CAST(210 as Decimal(29,16))/CAST(222 as Decimal(29,16)) --0.945945945
如您所见,随着精度的提高,答案的规模似乎在缩小。我看不到结果的规模与股息和除数的规模或精度之间的相关性。
我发现其他一些 SO 问题指向 msdn 文档中的一个地方,该文档指出在小数运算期间产生的精度和小数位数是通过对除数和被除数的精度和小数位数执行一组计算来确定的,并且:
The result precision and scale have an absolute maximum of 38. When a result precision is greater than 38, the corresponding scale is reduced to prevent the integral part of a result from being truncated.
所以我尝试自己运行这些方程式以确定将一个 Decimal(38,16)
分成另一个 Decimal(38,16)
的输出是什么样子,根据我的发现,我仍然应该得到比我得到的更精确的数字。
所以我要么做错了数学,要么这里发生了一些我遗漏的事情。如果您能提供任何见解,我将不胜感激。
提前致谢...
最佳答案
documentation关于值 6
的魔力以及何时应用 max
函数有点不完整,但这是我根据该文档得出的发现的表格。
正如它所说,除法公式是:
Result precision = p1 - s1 + s2 + max(6, s1 + p2 + 1), Result scale = max(6, s1 + p2 + 1)
而且,正如您自己强调的那样,我们有脚注:
The result precision and scale have an absolute maximum of 38. When a result precision is greater than 38, the corresponding scale is reduced to prevent the integral part of a result from being truncated.
所以,这是我在电子表格中生成的内容:
p1 s1 p2 s2 prInit srInit prOver prAdjusted srAdjusted
38 16 38 16 93 55 55 38 6
28 16 28 16 73 45 35 38 10
29 16 29 16 75 46 37 38 9
因此,我使用 pr
和 sr
来指示结果的精度和小数位数。 prInit
和 srInit
公式正是文档中的 forumlas。正如我们所见,在所有 3 种情况下,结果的精度都远远大于 38
,因此脚注适用。 prOver
只是 max(0,prInit - 38)
- 如果脚注适用,我们必须将精度调整多少。 prAdjusted
就是 prInit - prOver
。我们可以看到在这三种情况下,结果的最终精度都是38
。
如果我对比例应用相同调整因子,那么我将获得 0
、10
和 9
。但是我们可以看到,(38,16)
案例的结果的比例为 6
。所以我相信这就是文档的 max(6,...
部分实际适用的地方。所以我的 srAdjusted
的最终公式是 max(6, srInit-prOver)
现在我的最终 Adjusted
值似乎与您的结果相匹配。
当然,如果我们查阅 decimal
的文档,我们可以看到默认精度和小数位数,如果你不指定它们,都是(18,0)
,所以这是你没有指定时的行精度和比例:
p1 s1 p2 s2 prInit srInit prOver prAdjusted srAdjusted
18 0 18 0 37 19 0 37 19
关于SQL 服务器 : Decimal Precision/Scale are yielding strange results,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25297073/
function* generatorFunction() { yield (yield 1)(yield 2)(yield 3)(); } var iterator = generatorFun
ECMAScript 6 应该带来生成器函数和迭代器。生成器函数(具有 function* 语法)返回一个迭代器。迭代器有一个 next 方法,当重复调用时,该方法会执行生成器函数的主体,并在每个 y
ECMAScript 6 应该引入生成器函数和迭代器。生成器函数(具有 function* 语法)返回迭代器。迭代器有一个 next 方法,当重复调用时,它会执行生成器函数的主体,在每个 yield
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 2 年前。 Improve t
自 python 2.5 以来,可以将 send()、throw()、close() 放入生成器中。在定义的生成器中,可以通过执行以下操作来“捕获”发送的数据: def gen(): whil
return的区别和 yield似乎很清楚,直到我发现还有 yield from以及将两者结合起来的可能性 return和 yield在完全相同的功能! 我对return的理解之后的一切都是 不是 执
假设我有这个部分,我正在尝试渲染 #layouts/_subheader.html.erb 当我在这样的 View 中使用这个部分时 Content For Yield
yield操作符是由编译器在底层实现的,该编译器生成一个实现符合 IEnumerable 的状态机的类。和 IEnumerator . 给定一个罗斯林 MethodDeclarationSyntax
$item) echo "$index $item" . PHP_EOL; } resolve(generator1()); echo PHP_EOL; resolve(gener
这个问题在这里已经有了答案: Why converting list to set is faster than converting generator to set? (1 个回答) List c
是否有一个单行代码来获取生成器并生成该生成器中的所有元素?例如: def Yearly(year): yield YEARLY_HEADER for month in range(1, 13)
刚发现yield from 结构,在我看来这有点像反向的yield,而不是从生成器中获取对象,您插入/将对象发送到生成器。喜欢: def foo(): while True:
考虑以下代码: def mygen(): yield (yield 1) a = mygen() print(next(a)) print(next(a)) 输出产量: 1 None 解释器
Guido van Rossum,在 2014 年关于 Tulip/Asyncio 的演讲中 shows the slide : Tasks vs coroutines Compare: res =
谁能帮我理解“yield self”和“yield”的区别? class YieldFirstLast attr_accessor :first, :last def initiali
这是我目前使用 Laravel 5 实现的 Open Graph 标签: app.blade.php @yield('title') page.blade.php @extends('app'
在 Tornado 中,我们通常会编写如下代码来异步调用函数: class MainHandler(tornado.web.RequestHandler): @tornado.gen.coro
本文整理了Java中aQute.bnd.indexer.analyzers.Yield.yield()方法的一些代码示例,展示了Yield.yield()的具体用法。这些代码示例主要来源于Github
我们有超过 100 个共同基金的每日返回,我们希望将这些返回转换为月度返回。每月返回不应是每个月的平均值,而是每个月末的资金返回。基金在不同的时间点开始和结束,它们需要自己保留(不是每个月的共同基金
如何实现 C# yield return使用 Scala 延续?我希望能够编写 Scala Iterator s 风格相同。在 this Scala news post 的评论中有刺伤,但它不起作用(
我是一名优秀的程序员,十分优秀!