我有两个变量,一个叫PaidThisMonth,另一个叫OwedPast。它们都是SQL中一些子查询的结果。我如何选择两者中较小的一个,并将其作为一个名为PaidForPast的值返回?

MIN函数作用于列,而不是变量。


当前回答

这里有一个技巧,如果你想计算最大值(字段,0):

SELECT (ABS(field) + field)/2 FROM Table

如果字段为负,则返回0,否则返回字段。

其他回答

基于mathematix和scottyc的出色逻辑/代码,我提交:

DECLARE @a INT, @b INT, @c INT = 0;

WHILE @c < 100
    BEGIN
        SET @c += 1;
        SET @a = ROUND(RAND()*100,0)-50;
        SET @b = ROUND(RAND()*100,0)-50;
        SELECT @a AS a, @b AS b,
            @a - ( ABS(@a-@b) + (@a-@b) ) / 2 AS MINab,
            @a + ( ABS(@b-@a) + (@b-@a) ) / 2 AS MAXab,
            CASE WHEN (@a <= @b AND @a = @a - ( ABS(@a-@b) + (@a-@b) ) / 2)
            OR (@a >= @b AND @a = @a + ( ABS(@b-@a) + (@b-@a) ) / 2)
            THEN 'Success' ELSE 'Failure' END AS Status;
    END;

虽然从scottyc的MIN函数到MAX函数的跳跃对我来说应该是显而易见的,但它不是,所以我已经解决了它,并将其包含在这里:SELECT @a + (ABS(@b-@a) + (@b-@a)) / 2。这些随机生成的数字虽然不是证据,但至少应该让怀疑论者相信这两个公式都是正确的。

用例:

   Select Case When @PaidThisMonth < @OwedPast 
               Then @PaidThisMonth Else @OwedPast End PaidForPast

作为内联表值UDF

CREATE FUNCTION Minimum
(@Param1 Integer, @Param2 Integer)
Returns Table As
Return(Select Case When @Param1 < @Param2 
                   Then @Param1 Else @Param2 End MinValue)

用法:

Select MinValue as PaidforPast 
From dbo.Minimum(@PaidThisMonth, @OwedPast)

附录: 当只处理两个可能的值时,这可能是最好的,如果有两个以上,考虑Craig使用values子句的回答。

这里有一个技巧,如果你想计算最大值(字段,0):

SELECT (ABS(field) + field)/2 FROM Table

如果字段为负,则返回0,否则返回字段。

SQL Server 2012和2014支持IIF(cont,true,false)函数。因此,对于最小的选择,你可以使用它像

SELECT IIF(first>second, second, first) the_minimal FROM table

虽然IIF只是CASE…WHEN…ELSE,写起来更容易。

对于SQL Server 2022+(或MySQL或PostgreSQL 9.3+),更好的方法是使用LEAST和GREATEST函数。

SELECT GREATEST(A.date0, B.date0) AS date0, 
       LEAST(A.date1, B.date1, B.date2) AS date1
FROM A, B
WHERE B.x = A.x

:

GREATEST(value[,…]):返回所提供值中的最大(最大值)参数 LEAST(value[,…])从所提供的值中返回最小的(最小值)参数

文档链接:

MySQL http://dev.mysql.com/doc/refman/5.0/en/comparison-operators.html Postgres https://www.postgresql.org/docs/current/functions-conditional.html SQL Server https://learn.microsoft.com/en-us/sql/t-sql/functions/logical-functions-least-transact-sql