从这个问题,一个关于使用 COALESCE简化复杂逻辑树的简洁答案。我考虑了短路的问题。
例如,在大多数语言的函数中,参数都经过完全评估,然后传递给函数。在 C 中:
int f(float x, float y) {
return x;
}
f(a, a / b) ; // This will result in an error if b == 0
这似乎不是COALESCE
SQL Server 中“函数”的限制:
CREATE TABLE Fractions (
Numerator float
,Denominator float
)
INSERT INTO Fractions VALUES (1, 1)
INSERT INTO Fractions VALUES (1, 2)
INSERT INTO Fractions VALUES (1, 3)
INSERT INTO Fractions VALUES (1, 0)
INSERT INTO Fractions VALUES (2, 0)
INSERT INTO Fractions VALUES (3, 0)
SELECT Numerator
,Denominator
,COALESCE(
CASE WHEN Denominator = 0 THEN 0 ELSE NULL END,
CASE WHEN Numerator <> 0 THEN Numerator / Denominator ELSE NULL END,
0
) AS TestCalc
FROM Fractions
DROP TABLE Fractions
如果它在分母 = 0 时评估第二种情况,我预计会看到如下错误:
Msg 8134, Level 16, State 1, Line 1
Divide by zero error encountered.
我发现了一些与Oracle 相关的内容。以及一些使用SQL Server的测试。当您包含用户定义的函数时,看起来短路可能会发生故障。
那么,这种行为是否应该由 ANSI 标准来保证?