Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Trucos (https://www.clubdelphi.com/foros/forumdisplay.php?f=52)
-   -   Equivalencia del "Case" de SQL Server en Oracle (https://www.clubdelphi.com/foros/showthread.php?t=80709)

dec 01-07-2006 02:25:00

Equivalencia del "Case" de SQL Server en Oracle
 
En el SQL de SQL Server podemos realizar consultas como las siguientes

Código SQL [-]
Select Codigo, Nombre, Tipo = Case Sim When 'S' Then 'UNO' Else 'DOS' End From Articulos;

Con esta consulta podemos devolver valores diferentes, no estamos limitados solo a los dos del ejemplo, a partir de unos valores que ya conocemos previamente. Nos puede servir por ejemplo para formatear valores de campos de Estado.

Ahora bien si esto lo queremos realizar con Oracle, este SQL no aguanta la clausula CASE. En este caso podemos utilizar la clausula <b>DECODE</b>, esta clausula es equivalente al CASE.

Aplicandolo al ejemplo anterior nos quedaría algo del estilo:

Código SQL [-]
Select Codigo, Nombre, DECODE(Tipo,
'S' , 'UNO',
'DOS')
From Articulos;

Dentro del paréntesis se especifica en primer lugar el campo o variable y a continuación las parejas de valores (valor real y valor transformado) que queramos y por último el valor que debe devolver cuando encuentre un valor en el campo que no se especifique en el decode.

Un Ejemplo más complejo sería:

Código SQL [-]
DECODE(Numero,
'1', 'UNO',
'2', 'DOS',
'3', 'TRES',
'4', 'CUATRO',
'SUPERIOR A CUATRO')


La franja horaria es GMT +2. Ahora son las 12:14:11.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi