Teradata - CASE dan COALESCE

Bab ini menjelaskan fungsi CASE dan COALESCE dari Teradata.

Ekspresi CASE

Ekspresi CASE mengevaluasi setiap baris terhadap kondisi atau klausa WHEN dan mengembalikan hasil dari kecocokan pertama. Jika tidak ada yang cocok maka hasil dari ELSE bagian dari dikembalikan.

Sintaksis

Berikut ini adalah sintaks dari ekspresi CASE.

CASE <expression> 
WHEN <expression> THEN result-1 
WHEN <expression> THEN result-2 

ELSE  
   Result-n 
END

Contoh

Perhatikan tabel Karyawan berikut.

KaryawanNo Nama depan Nama keluarga JoinedDate DepartemenNo Tanggal lahir
101 Mike James 27/3/2005 1 1/5/1980
102 Robert Williams 25/4/2007 2 3/5/1983
103 Peter Paul 21/3/2007 2 1/4/1983
104 Alex Stuart 1/2/2008 2 6/11/1984
105 Robert James 1/4/2008 3 1/12/1984

Contoh berikut mengevaluasi kolom DepartmentNo dan mengembalikan nilai 1 jika nomor departemen adalah 1; mengembalikan 2 jika nomor departemen adalah 3; jika tidak, ia mengembalikan nilai sebagai departemen yang tidak valid.

SELECT 
   EmployeeNo, 
CASE DepartmentNo 
   WHEN 1 THEN 'Admin' 
   WHEN 2 THEN 'IT' 
ELSE 'Invalid Dept'
   END AS Department 
FROM Employee;

Ketika query di atas dijalankan, itu menghasilkan keluaran sebagai berikut.

*** Query completed. 5 rows found. 2 columns returned. 
*** Total elapsed time was 1 second. 
 EmployeeNo    Department 
-----------   ------------ 
   101         Admin 
   104         IT 
   102         IT 
   105         Invalid Dept 
   103         IT

Ekspresi CASE di atas juga bisa ditulis dalam bentuk berikut yang akan menghasilkan hasil yang sama seperti di atas.

SELECT 
   EmployeeNo, 
CASE  
   WHEN DepartmentNo = 1 THEN 'Admin' 
   WHEN  DepartmentNo = 2 THEN 'IT' 
ELSE 'Invalid Dept' 
   END AS Department  
FROM Employee;

BERSATU

COALESCE adalah pernyataan yang mengembalikan nilai bukan-null pertama dari ekspresi tersebut. Ia mengembalikan NULL jika semua argumen ekspresi mengevaluasi ke NULL. Berikut adalah sintaksnya.

Sintaksis

COALESCE(expression 1, expression 2, ....)

Contoh

SELECT 
   EmployeeNo, 
   COALESCE(dept_no, 'Department not found') 
FROM  
   employee;

NULLIF

Pernyataan NULLIF mengembalikan NULL jika argumennya sama.

Sintaksis

Berikut ini adalah sintaks dari pernyataan NULLIF.

NULLIF(expression 1, expression 2)

Contoh

Contoh berikut mengembalikan NULL jika DepartmentNo sama dengan 3. Jika tidak, ia mengembalikan nilai DepartmentNo.

SELECT 
   EmployeeNo,  
   NULLIF(DepartmentNo,3) AS department 
FROM Employee;

Kueri di atas mengembalikan rekaman berikut. Anda dapat melihat bahwa karyawan 105 memiliki no departemen. sebagai NULL.

*** Query completed. 5 rows found. 2 columns returned. 
*** Total elapsed time was 1 second. 
 EmployeeNo      department 
-----------  ------------------ 
    101              1 
    104              2 
    102              2 
    105              ? 
    103              2