我有两个变量,一个叫PaidThisMonth,另一个叫OwedPast。它们都是SQL中一些子查询的结果。我如何选择两者中较小的一个,并将其作为一个名为PaidForPast的值返回?
MIN函数作用于列,而不是变量。
我有两个变量,一个叫PaidThisMonth,另一个叫OwedPast。它们都是SQL中一些子查询的结果。我如何选择两者中较小的一个,并将其作为一个名为PaidForPast的值返回?
MIN函数作用于列,而不是变量。
当前回答
Select MIN(T.V) FROM (Select 1 as V UNION Select 2 as V) T
其他回答
对于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
SQL Server 2012和2014支持IIF(cont,true,false)函数。因此,对于最小的选择,你可以使用它像
SELECT IIF(first>second, second, first) the_minimal FROM table
虽然IIF只是CASE…WHEN…ELSE,写起来更容易。
基于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。这些随机生成的数字虽然不是证据,但至少应该让怀疑论者相信这两个公式都是正确的。
使用CASE、IIF和UDF的解决方案是足够的,但是当将问题扩展到使用超过2个比较值的一般情况时是不切实际的。广义 SQL Server 2008+中的解决方案利用VALUES子句的一个奇怪应用:
SELECT
PaidForPast=(SELECT MIN(x) FROM (VALUES (PaidThisMonth),(OwedPast)) AS value(x))
由于本网站: http://sqlblog.com/blogs/jamie_thomson/archive/2012/01/20/use-values-clause-to-get-the-maximum-value-from-some-columns-sql-server-t-sql.aspx
使用临时表插入值范围,然后从存储过程或UDF中选择临时表的最小/最大值。这是一个基本的结构,所以可以根据需要随意修改。
例如:
CREATE PROCEDURE GetMinSpeed() AS
BEGIN
CREATE TABLE #speed (Driver NVARCHAR(10), SPEED INT);
'
' Insert any number of data you need to sort and pull from
'
INSERT INTO #speed (N'Petty', 165)
INSERT INTO #speed (N'Earnhardt', 172)
INSERT INTO #speed (N'Patrick', 174)
SELECT MIN(SPEED) FROM #speed
DROP TABLE #speed
END