SQL Server 2008を使用して複数のCASE WHEN条件を実行するにはどうすればよいですか?


173

私がやろうとしていることは、同じ列に複数のCASE WHEN条件を使用することです。

クエリのコードは次のとおりです。

   SELECT   Url='',
            p.ArtNo,
            p.[Description],
            p.Specification,
            CASE 
            WHEN 1 = 1 or 1 = 1 
               THEN 1 
               ELSE 0 
            END as Qty,
            p.NetPrice,
            [Status] = 0
      FROM  Product p (NOLOCK)

ただし、私がやりたいのは、同じ列「qty」に複数のWHENを使用することです。

次のコードのように:

IF
// CODE
ELSE IF
// CODE
ELSE IF
// CODE
ELSE
// CODE

8
case when <condition> then <vaue> when <condition> then <value> . . . endそれが機能していないことについて何かありますか?
ゴードンリノフ2013年

1
@GordonLinoffが言っていたように、複数のを持つことができますWHEN
Kermit 2013年

それはあなたが言うとおりです。括弧を間違った場所に置いていました。ごめんね!
Nils Anders

回答:


389

ケース式に2つの形式があります。あなたはCASE多くのことを行うことができますWHEN

CASE  WHEN Col1 = 1 OR Col3 = 1  THEN 1 
      WHEN Col1 = 2 THEN 2
      ...
      ELSE 0 END as Qty

または単純なCASE表現

CASE Col1 WHEN 1 THEN 11 WHEN 2 THEN 21 ELSE 13 END

または CASE CASEとして;

CASE  WHEN Col1 < 2 THEN  
                    CASE Col2 WHEN 'X' THEN 10 ELSE 11 END
      WHEN Col1 = 2 THEN 2
      ...
      ELSE 0 END as Qty

30
二つあります。 リスト3:D
d8aninja

外側のケースがtrueを返さない場合、内側のケースは検証されていますか?
ggderas 2017

3
@ d8aninja彼らは2のみをリストしました。3番目は、最初の2つを組み合わせたもので、外側のケースが最初のタイプで、内側のケースが2番目のタイプです。
'19

12

これを使用するだけで、クラスの場合はさらに使用する必要があります。

SELECT   Url='',
         p.ArtNo,
         p.[Description],
         p.Specification,
         CASE 
         WHEN 1 = 1 or 1 = 1 
            THEN 1 
         WHEN 2 = 2
             THEN 2
         WHEN 3 = 3
              THEN 3
          ELSE 0 
        END as Qty,
        p.NetPrice,
        [Status] = 0
  FROM  Product p (NOLOCK)

3

複数の条件がある場合、以下のケースの例を使用できます。

SELECT
  id,stud_name,
  CASE
    WHEN marks <= 40 THEN 'Bad'
    WHEN (marks >= 40 AND
      marks <= 100) THEN 'good'
    ELSE 'best'
  END AS Grade
FROM Result

2

これは、1つのステートメントでさまざまなテストを実行する効率的な方法です。

select
case colour_txt 
  when 'red' then 5 
  when 'green' then 4 
  when 'orange' then 3
else 0 
end as Pass_Flag

これは等価比較でのみ機能します!


1
    case when first_condition
      then first_condition_result_true
    else
      case when second_condition 
        then second_condition_result_true
      else
          second_condition_result_false                              
      end
    end
  end as qty

5
このようなCASES式をネストする必要はありません。1つのCASEに複数のWHEN句を含めることができます。
Barmar 2013年

2
最初の条件が満たされると、残りの条件は無視されますか?

1
case 
    when a.REASONID in ('02','03','04','05','06') then
        case b.CALSOC 
            when '1' then 'yes' 
            when '2' then 'no' 
            else 'no' 
        end
    else 'no' 
end 

1
答えをフォーマットして、説明を追加してください。
tmt 2015年

0

私は同様のものがありましたが、それは日付を扱っていました。先月のすべてのアイテムを表示するクエリ。1月まで無条件で問題なく機能します。正しく機能させるには、年と月の変数を追加する必要があります。

declare @yr int
declare @mth int

set @yr=(select case when month(getdate())=1 then YEAR(getdate())-1 else YEAR(getdate())end)
set @mth=(select case when month(getdate())=1 then month(getdate())+11 else month(getdate())end)

次に、変数を条件に追加します:...

(year(CreationTime)=@yr and MONTH(creationtime)=@mth)

0

すべての条件を組み合わせる

select  a.* from tbl_Company a

where  a.Company_ID NOT IN (1,2)  

AND (   
        (0 = 
            CASE WHEN (@Fromdate = '' or @Todate='')
                THEN 0 
                ELSE 1  
            END
        )      -- if 0=0 true , if 0=1 fails (filter only when the fromdate and todate is present)
                OR
        (a.Created_Date between @Fromdate and @Todate )                 
    )

0

このようなもの、2つの条件、2つの列

SELECT ITEMSREQ.ITEM AS ITEM,
       ITEMSREQ.CANTIDAD AS CANTIDAD,
       (CASE  WHEN ITEMSREQ.ITEMAPROBADO=1 THEN 'APROBADO'
              WHEN ITEMSREQ.ITEMAPROBADO=0 THEN 'NO APROBADO'
        END) AS ITEMS,
        (CASE 
              WHEN ITEMSREQ.ITEMAPROBADO = 0 
              THEN CASE WHEN REQUISICIONES.RECIBIDA IS NULL  THEN 'ITEM NO APROBADO PARA ENTREGA' END
              WHEN ITEMSREQ.ITEMAPROBADO = 1 
              THEN CASE WHEN REQUISICIONES.RECIBIDA IS NULL THEN 'ITEM AUN NO RECIBIDO' 
                        WHEN REQUISICIONES.RECIBIDA=1 THEN 'RECIBIDO' 
                        WHEN REQUISICIONES.RECIBIDA=0 THEN 'NO RECIBIDO' 
                       END
              END)
              AS RECIBIDA
 FROM ITEMSREQ
      INNER JOIN REQUISICIONES ON
      ITEMSREQ.CNSREQ = REQUISICIONES.CNSREQ

0

それはあなたがWhenそれを振る舞うために単一のケースのために複数が必要であるということだけですif.. Elseif else..

   Case when 1=1       //if
   Then
    When 1=1              //else if
     Then.... 
    When .....              //else if
    Then 
    Else                      //else
   ....... 
     End
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.