Skip to main content

PostgreSQL | Cross Tabulation Dengan Ekspresi Kondisional CASE

Pada posting sebelumnya, saya sudah berbagi tentang cara menggunakan ekspresi kondisional CASE pada query. Sekarang saya ingin berbagi cara untuk memanfaatkan ekspresi CASE untuk membentuk cross tabulation query. Apa itu cross tabulation? Silahkan baca di wikipedia untuk lebih detail. :P

Secara sederhana saya mengartikan cross tabulation adalah menyajikan data dari baris menjadi kolom.
Berikut contoh sederhana untuk menggambarkan apa itu cross tabulation.


SELECT * FROM siswa ORDER BY siswaid;

 siswaid |      nama      | sex
---------+----------------+-----
       1 | Eko Suhariyadi | L
       2 | Mori Ran       | P
       3 | Megumi Noda    | P
       4 | Haruka Koga    | P
       5 | Hiro Kunimi    | L
(5 rows)

Dari data tersebut akan kita sajikan informasi seperti berikut ini:

 laki | perempuan
------+-----------
    2 |         3
(1 row)

Dapat dilihat bahwa kita mentransformasikan data sex menjadi kolom. Mudah-mudahan contoh tersebut dapat membantu sahabat untuk memahami apa itu cross tabulation.

Sekarang langsung saja kita buat implementasinya di PostgreSQL.

SELECT 
COUNT(CASE WHEN sex='L' THEN 1 ELSE NULL END) AS Laki, 
COUNT(CASE WHEN sex='P' THEN 1 ELSE NULL END) AS Perempuan 
FROM siswa;

Bagaimana, sangat menarik bukan?! :D

Happy querying

Comments

Popular posts from this blog

PostgreSQL | Membuat Nomor Urut dengan Window Function ROW_NUMBER()

Pengguna Oracle Database mungkin sudah sangat familiar dengan clausa ROWNUM. Bagi yang belum tahu apa itu ROWNUM,  ROWNUM  adalah  pseudo column  (kolom bayangan) yang berisi nomor urut dari hasil eksekusi query. Sayangnya fitur ini belum tersedia pada PostgreSQL . Namun ada kabar gembira bagi kita pengguna  PostgreSQL , dimana sejak versi 8.4, PostgreSQL telah menyediakan 1 window function  yang mengakomodasi masalah ROWNUM, yakni ROW_NUMBER() . Sesuai dengan dokumentasi yang disediakan, cara menggunakan fungsi ini adalah dengan menggabungkannya dengan clausa OVER  yang didalamnya berisi clausa ORDER BY . Supaya lebih jelas dan lebih mudah dipahami, lebih baik langsung kita praktekkan saja. Saya membuat sebuah table dengan struktur sebagai berikut CREATE TABLE name ( code CHAR(1) ); yang kemudian saya isi kolom code dengan alfabet mulai dari a s/d z  dan angka 0 (nol). Sebelumnya kita lakukan query ke table name tanpa clausa O...

Java | Menambahkan Dialog Konfirmasi Sebelum Keluar dari Aplikasi

Kali ini saya ingin berbagi cara sederhana untuk menampilkan dialog konfirmasi sebelum keluar dari aplikasi. Dengan syarat aplikasi yang kita buat harus menggunakan JFrame sebagai frame utama. Langkah-langkah yang harus kita lakukan adalah sebagai berikut: 1. Ganti property default close operation dari JFrame menjadi DO_NOTHING_ON_CLOSE, value ini dimaksudkan agar ketika button close dari JFrame diklik tidak akan terjadi apa-apa. Sebaliknya jika valuenya adalah EXIT_ON_CLOSE, maka ketika button close dari JFrame diklik maka program akan tertutup. setDefaultCloseOperation(DO_NOTHING_ON_CLOSE); 2. Yang kedua adalah kita harus menambahkan WindowListener pada JFrame. Interface WindowListener memiliki beberapa method terkait event terhadap window (yakni JFrame), namun yang harus kita override hanyalah method windowClosing, method ini akan dipanggil ketika button close diklik.   Sebagai informasi, apabila kita menambahkan WindowListener secara langsung ...

Hardware | Banyak Bersyukur dengan SSD

Seperti yang sudah saya sampaikan pada post sebelumnya, kali ini saya mau membahas upgrade laptop saya ke SSD sebagai "main" hard drive . Saya sudah cukup banyak mendengar mengenai hebatnya kecepatan yang ditawarkan SSD, namun belum mempunyai keinginan untuk upgrade karena ketidaktahuan saya bahwa ada cara untuk memasang SSD ke laptop secara mandiri (*Saya beralih dari PC ke laptop karena adik saya membutuhkan PC saya). Beruntung saya mengikuti feed dari blog Mas Vatih dan menemukan satu artikel menarik mengenai cara memasang SSD di Macbook miliknya. Berbekal info dari post tersebut dan uang tabungan yang cukup, saya memutuskan untuk mencobanya. Saya membeli SSD Crucial MX200 250GB dan HDD Caddy SATA 12.7mm dari JakartaNotebook.com *bukan iklan. Bagi yang belum tahu, HDD Caddy adalah suatu alat yang digunakan untuk memasang hard drive pada slot DVD ROM. Berikut penampakan HDD Caddy HDD Caddy 12.7mm *mirip DVD ROM kan ^^ Perlu diketahui juga bahwa HDD Caddy ...