web-dev-qa-db-ja.com

SQL ServerのDECODE()関数

SELECT PC_COMP_CODE,
       'R',
       PC_RESUB_REF,
       DECODE(PC_SL_LDGR_CODE, '02', 'DR', 'CR'),
       PC_DEPT_NO DEPT,
       '', --PC_DEPT_NO,
       PC_SL_LDGR_CODE + '/' + PC_SL_ACNO,
       SUM(DECODE(PC_SL_LDGR_CODE, '02', 1, -1) * PC_AMOUNT),
       PC_CHEQUE_NO CHQNO
  FROM GLAS_PDC_CHEQUES
 WHERE PC_RESUB_REF IS NOT NULL 
   AND PC_DISCD NOT IN ('d', 'D', 'T') 
GROUP BY PC_RESUB_REF, 
         PC_COMP_CODE, 
         'JJ', 
         PC_SL_LDGR_CODE + '/' + PC_SL_ACNO, 
         PC_DEPT_NO, 
         PC_CHEQUE_NO, 
         DECODE(PC_SL_LDGR_CODE, '02', 'DR', 'CR')

上記はOracleクエリです。 SQL Server 2005でDECODE()関数を使用するにはどうすればよいですか?

28
Domnic

SQLで 'CASE .. WHEN .. THEN .. ELSE .. END'構文を使用できます。

49
daxsorbito

私が質問を正しく理解している場合、デコードと同等の機能が必要ですが、T-SQLで

Select YourFieldAliasName =
CASE PC_SL_LDGR_CODE
    WHEN '02' THEN 'DR'
    ELSE 'CR'
END
24
Andrew

完全を期すために(誰も最も明白な答えを投稿していないため):

Oracle:

DECODE(PC_SL_LDGR_CODE, '02', 'DR', 'CR')

MSSQL:

IIF(PC_SL_LDGR_CODE='02', 'DR', 'CR')

悪いニュース:

DECODEの引数が4つを超えると、いIIFカスケードが発生します

14
Daniel Alder

以下のようにSQL Serverで関数を作成し、DECODEdbo.DECODEに置き換えます

CREATE FUNCTION DECODE(@CondField as nvarchar(100),@Criteria as nvarchar(100), 
                       @True Value as nvarchar(100), @FalseValue as nvarchar(100))
returns nvarchar(100)
begin
       return case when @CondField = @Criteria then @TrueValue 
                   else @FalseValue end
end
3
Anidesh

簡単です:

select 
    CASE WHEN 10 > 1 THEN 'Yes'
    ELSE 'No'
END 
2

この「リテラルテーブル」に参加し、

select 
    t.c.value('@c', 'varchar(30)') code,
    t.c.value('@v', 'varchar(30)') val
from (select convert(xml, '<x c="CODE001" v="Value One" /><x c="CODE002" v="Value Two" />') aXmlCol) z
cross apply aXmlCol.nodes('/x') t(c)
1
Jacques Bach

関数を使用するとき

select dbo.decode(10>1 ,'yes' ,'no')

次に、「>」の近くに構文エラーがあります

残念ながら、最初の関数引数の型と一致するように論理式をビットパラメーターに変換する必要があるため、SQLにCASE句を含めることはできません。

create function decode(@var1 as bit, @var2 as nvarchar(100), @var3 as nvarchar(100))
returns nvarchar(100)
begin
return case when @var1 = 1 then @var2 else @var3 end;
end;

select dbo.decode(case when 10 > 1 then 1 else 0 end, 'Yes', 'No');
0