Teradata - Operator Logis dan Bersyarat

Teradata mendukung operator logis dan bersyarat berikut. Operator ini digunakan untuk melakukan perbandingan dan menggabungkan beberapa kondisi.

Sintaksis Berarti
> Lebih besar dari
< Kurang dari
>= Lebih dari atau sama dengan
<= Kurang dari atau sama dengan
= Sama dengan
BETWEEN Jika nilai dalam jangkauan
IN Jika nilai dalam <ekspresi>
NOT IN Jika nilai tidak dalam <ekspresi>
IS NULL Jika nilainya NULL
IS NOT NULL Jika nilainya NOT NULL
AND Gabungkan beberapa kondisi. Mengevaluasi menjadi benar hanya jika semua ketentuan terpenuhi
OR Gabungkan beberapa kondisi. Mengevaluasi menjadi benar hanya jika salah satu ketentuan terpenuhi.
NOT Membalik arti dari kondisi

ANTARA

Perintah BETWEEN digunakan untuk memeriksa apakah suatu nilai berada dalam kisaran nilai.

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 mengambil rekaman dengan nomor karyawan dalam kisaran antara 101.102 dan 103.

SELECT EmployeeNo, FirstName FROM  
Employee 
WHERE EmployeeNo BETWEEN 101 AND 103;

Ketika kueri di atas dijalankan, ia mengembalikan catatan karyawan dengan no karyawan antara 101 dan 103.

*** Query completed. 3 rows found. 2 columns returned. 
*** Total elapsed time was 1 second. 
 EmployeeNo            FirstName 
-----------  ------------------------------ 
   101                   Mike 
   102                   Robert 
   103                   Peter

DI

Perintah IN digunakan untuk memeriksa nilai terhadap daftar nilai yang diberikan.

Contoh

Contoh berikut mengambil record dengan nomor karyawan di 101, 102 dan 103.

SELECT EmployeeNo, FirstName FROM  
Employee 
WHERE EmployeeNo in (101,102,103);

Kueri di atas mengembalikan rekaman berikut.

*** Query completed. 3 rows found. 2 columns returned. 
*** Total elapsed time was 1 second.  
 EmployeeNo            FirstName 
-----------  ------------------------------ 
   101                   Mike 
   102                   Robert 
   103                   Peter

TIDAK MASUK

Perintah NOT IN membalikkan hasil dari perintah IN. Ini mengambil catatan dengan nilai yang tidak cocok dengan daftar yang diberikan.

Contoh

Contoh berikut mengambil record dengan nomor karyawan bukan 101, 102 dan 103.

SELECT * FROM  
Employee 
WHERE EmployeeNo not in (101,102,103);

Kueri di atas mengembalikan rekaman berikut.

*** Query completed. 2 rows found. 6 columns returned. 
*** Total elapsed time was 1 second. 
 EmployeeNo          FirstName                      LastName 
----------- ------------------------------ -----------------------------    
    104                Alex                          Stuart 
    105                Robert                        James