1

假设我有一个表T,它有一个属性A,一个整数。

MAX(T) + 1如果T包含 5 而MAX(T) + 2不是,如何使 SQL 查询返回?

4

3 回答 3

2
SELECT MAX(a) + CASE WHEN (5 IN (SELECT a FROM t)) THEN 1 ELSE 2 END AS max_plus_something FROM t
于 2012-07-12T05:35:39.813 回答
1
SELECT MAX(A) + MIN(CASE A WHEN 5 THEN 1 ELSE 2 END) AS NewA FROM T
于 2012-07-12T07:08:39.960 回答
0

我没有机会测试很多案例,但我认为这可以做你想要的。

declare @MinPosNI int;
set @MinPosNI = 1;
select @MinPosNI = case when (A - @MinPosNI) > 0 then @MinPosNI else A + 1 end from T     where A > 0 order by A 
select @MinPosNI
于 2012-07-12T06:59:21.453 回答