Ver Mensaje Individual
  #1  
Antiguo 01-07-2006
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.107
Reputación: 34
dec Tiene un aura espectaculardec Tiene un aura espectacular
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')
Responder Con Cita