Bekerja dengan nilai NULL

Pengantar Oracle SQL

Hadrien Lacroix

Content Developer

Apa itu nilai NULL?

  • Tidak ada nilai
  • Beda dengan 0
  • Ekspresi aritmetika dengan NULL bernilai NULL
    • NULL + 10 = NULL
  • Fungsi agregat biasanya mengabaikan NULL
    • COUNT tidak menghitung NULL dalam kolom
Pengantar Oracle SQL

Mengapa peduli dengan nilai null?

Data dunia nyata tidak sempurna.

  • Bersihkan data
  • Analisis data hilang
Pengantar Oracle SQL

Menguji apakah nilai bernilai NULL

= tidak bisa dipakai untuk menguji NULL

Gunakan:

  • IS NULL
    SELECT * FROM Customer WHERE LastName IS NULL
    
  • IS NOT NULL
    SELECT * FROM Customer WHERE LastName IS NOT NULL
    
Pengantar Oracle SQL

NVL

NVL(x, y): ubah x, yang bisa bernilai null, menjadi y, nilai non-null.

SELECT NVL(HireDate, '11/19/2004')
FROM Employee
Pengantar Oracle SQL

NULLIF

NULLIF(x, y): Membandingkan x dan y, mengembalikan

  • NULL jika x=y
  • x jika tidak sama
SELECT c.CustomerId, i.BillingCity, c.City, NULLIF(i.BillingCity, c.City) 
FROM Invoice i, Customer c
| CustomerId | BillingCity | City      | NULLIF |
|------------|-------------|-----------|--------|
| 48         | Oslo        | Amsterdam | Oslo   |
| 49         | Boston      | Vienne    | Boston |
| 59         | London      | London    | NULL   |
Pengantar Oracle SQL

COALESCE

COALESCE: mengembalikan nilai pertama yang bukan null dalam daftar

SELECT CustomerId, COALESCE(phone, email, fax) AS ContactMethod
FROM Customer
| CustomerId | ContactMethod           |
|------------|-------------------------|
| 59         | +91 080 22289999        |
| 58         | [email protected] |
| 57         | +56 (0)2 635 4444       |
Pengantar Oracle SQL

Ayo berlatih!

Pengantar Oracle SQL

Preparing Video For Download...