在SQL Server中有一个Max函数需要两个值,如Math.Max在.NET中?

我想写一个这样的查询:

SELECT o.OrderId, MAX(o.NegotiatedPrice, o.SuggestedPrice)
FROM Order o

但这不是MAX功能如何工作,对吧?它是一个聚合函数,因此它需要一个参数,然后返回所有行的最大值。

有谁知道如何做我的方式吗?

最佳答案
如果你想有类似于你的例子的语法,你可能需要创建一个用户定义的函数,但是你可以使用CASE语句相当容易地做内联的事情,正如其他人所说的那样。

UDF可能是这样的:

create function dbo.InlineMax(@val1 int, @val2 int)
returns int
as
begin
  if @val1 > @val2
    return @val1
  return isnull(@val2,@val1)
end

…你会这样叫它…

SELECT o.OrderId, dbo.InlineMax(o.NegotiatedPrice, o.SuggestedPrice) 
FROM Order o

转载注明原文:在SQL Server中有一个Max函数需要两个值,如Math.Max在.NET中? - 代码日志