T
1つの属性、A
整数を持つテーブルがあるとしましょう。
5が含まれている場合と含まれていないMAX(T) + 1
場合にSQLクエリを返すにはどうすればよいですか?T
MAX(T) + 2
SELECT MAX(a) + CASE WHEN (5 IN (SELECT a FROM t)) THEN 1 ELSE 2 END AS max_plus_something FROM t
SELECT MAX(A) + MIN(CASE A WHEN 5 THEN 1 ELSE 2 END) AS NewA FROM T
私は多くのケースをテストする機会がありませんが、これはあなたが望むことをすることができると思います。
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