MODUL 10
ADVANCE SQL 2
A.
Tujuan
Mahasiswa
mampu menggunakan select statements beserta options-nya untuk mencari,
mengolah, dan menampilkan data yang ada di basis data sesuai dengan
kebutuhannya.
B.
Landasan
Teori
·
IN
ü Contoh
-
SELECT*FROM rekening WHERE kode_cabang
IN (‘BRUM’,’BRUL’);
ü Perintah
SQL diatas sama dengan :
-
SELECT*FROM rekening WHERE kode_cabang =
‘BRUM’ OR kode_cabang = ‘BRUL’;
ü Tidak
ada batas banyaknya nilai yang bisa ada di dalam IN (….)
·
NOT
IN
ü Contoh
-
SELECT*FROM rekening WHERE kode_cabang
NOT IN (‘BRUS’,’BRUL’)
ü Nilai
NULL tidak akan tampil dalam IN dan NOT IN.
·
BETWEEN
ü Contoh
-
SELECT*FROM rekening WHERE saldo BETWEEN
500000 AND 1000000;
ü Nilai
yang pertama dalam BETWEEN harus lebih kecil dari nilai yang kedua.
·
NOT
BETWEEN
ü Contoh
-
SELECT*FROM rekening WHERE saldo NOT
BETWEEN 500000 AND 1000000;
·
AGGREGATE
FUNCTION
Fungsi-fungsi untuk aggregate :
·
MIN
( )
ü Digunakan
untuk mencari nilai terkecil dari sekumpulan record.
ü Contoh
-
SELECT MIN (saldo) FROM rekening;
ü Bisa
dibatasi dengan WHERE clause sehingga hanya record tertentu yang ditelusuri :
-
SELECT MIN (Saldo) FROM rekening WHERE
kode_cabang=’BRUS’;
·
MAX
( )
ü Digunakan
untuk mencari nilai terbesar dari sekumpulan record.
ü Contoh
-
SELECT MAX (saldo) FROM rekening;
ü Bisa
dibatasi dengan WHERE clause :
-
SELECT MAX (Saldo) FROM rekening WHERE
kode_cabang=’BRUS’;
·
COUNT
( )
ü Digunakan
untuk menghitung banyaknya record.
ü Contoh
- SELECT COUNT (*) FROM
nasabah;
- SELECT
COUNT(nama_nasabah) FROM nasabah;
- SELECT COUNT
(alamat_nasabah) FROM nasabah;
ü Bisa
dibatasi dengan WHERE clause.
ü Jika
kita ingin menghitung record yang unik (tidak ada pengulangan) maka gunakan
DISTINCT.
-
SELECT COUNT (DISTINCT alamat_nasabah)
FFROM nasabah;
·
SUM
( )
ü Digunakan
untuk menjumlahakan nilai-nilai dari sekumpulan record.
ü Contoh
-
SELECT SUM(saldo)FROM rekening;
ü Bisa
dibatasi dengan WHERE clause.
·
AVG
( )
ü Digunaakn
untuk menghitung rata-rata nilai dari sekumpulan record.
ü Contoh
-
SELECT AVG (saldo) FROM rekening;
ü Bisa
dibatasi dengan WHERE clause.
ü Beberapa
aggregate functions bisa digabungkan dalam satu perintah SQL :
-
SEELCT MIN(saldo), MAX (saldo), AVG
(saldo) FROM rekening;
ü Bisa
menggunakan Column Alias (AS) untuk membuat tampilan lebih professional.
·
GROUP
BY
ü Digunakan
untuk mengelompokkan sekumpulan record berdasarkan (kolom-kolom) tertentu.
ü Contoh
-
SELECT jenis_transaksi FROM transaksi
GROUP BY jenis_transaksi;
·
HAVING
ü Merupakan
pasangan dari GROUP BY, digunakan untuk membatasi yang ditampikan.
ü Contoh
-
SELECT jenis_transaksi, tanggal FROM
transaksi GROUP BY jenis_transaksi, tanggal HAVING jenis_transaksi-‘kredit’;
ü Jika
menggunakan HAVING, maka pembatasan dilakukan setelah dikelompokkan dalam GROUP
BY.
ü Jika
menggunakan WHERE, maka pembatasan dilakukan sebelum hasil dikelompokkan dalam
GROUP BY.
·
GROUP
BY dan AGGREGATE
ü GROUP
BY sangat cocok untuk aggregate functions. Dengan menggunakan GROUP BY, kita
bisa mengelompokkan record-record dan menghitung min, max, count, sum, dan avg
untuk masing-masing kelompok.
-
SELECT kode_cabang, MIN(saldo),
MAX(saldo), COUNT(*), SUM(saldo), AVG(saldo) FROM rekening GROUP BY kode_cabang;
ü Bisa
digabungkan dengan tabel join dan ORDER BY.
-
SELECT nama_cabang, SUM(saldo) FROM
rekening NATURAL JOIN cabang_bank GROUP BY nama_cabang ORDER BY nama_cabang;
C.
Alat
dan Bahan
1. Komputer
dengan sistem operasi Windows 7.
2. Program
aplikasi PostgreSQL 9.3.
3. Modul
Praktikum Sistem Basis Data.
D.
Langkah
Kerja
1. Tampilkan
nama nasabah, jenis transaksi, dan rata-rata jumlah transaksi (dalam rupiah)
untuk tiap nasabah yang telah melakukan transaksi dan diurutkan berdasarkan
rata-rata jumlah transaksi dengan kode berikut:
-
SELECT nasabah.nama_nasabah AS “Nama
Nasabah”, transaksi.jenis_transaksi AS “Jenis Transaksi”, AVG(transaksi.jumlah)
AS “Rata-rata (Rp)” FROM transaksi, nasabah WHERE
nasabah.id_nasabah=transaksi.id_nasabahFK GROUP BY nasabah.nama_nasabah,
transaksi.jenis_transaksi ORDER BY “Rata-rata (Rp)”;
2. Tampilkan
nama nasabah, jenis transaksi, banyaknya transaksi, dan total jumlah transaksi
(dalam rupiah) untuk tiap nasabah yang telah melakukan transaksi debit pada
bulan Desember 2009 dan diurutkan berdasarkan total jumlah transaksi dari yang
terbesar sampai terkecil dengan kode berikut:
-
SELECT nasabah.nama_nasabah AS “Nama
Nasabah”, transaksi.jenis_transaksi AS “Jenis Transaksi”,
COUNT(transaksi.jumlah) AS “Jumlah Transaksi”, SUM(transaksi.jumlah) AS “Jumlah
(Rp)” FROM transaksi, nasabah WHERE nasabah.id_nasabah=transaksi.id_nasabahFK
GROUP BY nasabah.nama_nasabah, transaksi.jenis_transaksi ORDER BY “Jumlah
Transaksi” DESC;
3. Tampilkan
nama cabang bank, jenis transaksi, total jumlah transaksi (dalam rupiah), dan
banyaknya transaksi yang telah dilayani oleh tiap cabang bank dan diurutkan
berdasarkan nama cabang bank dan jenis transaksi dengan kode berikut:
-
SELECT cabang_bank.nama_cabang AS “Nama
Cabang”, transaksi.jenis_transaksi AS “Jenis Transaksi”, SUM(transaksi.jumlah)
AS “Jumlah (Rp)”, COUNT(transaksi.jumlah) AS “Jumlah Transaksi” FROM transaksi,
cabang_bank, rekening WHERE cabang_bank.kode_cabang=rekening.kode_cabangFK AND
rekening.no_rekening=transaksi.no_rekeningFK GROUP BY cabang_bank.nama_cabang,
transaksi.jenis_transaksi ORDER BY cabang_bank.nama_cabang,
transaksi.jenis_transaksi;
4. Tampilkan
nama cabang bank, jenis transaksi, dan rata-rata jumlah transaksi (dalam
rupiah) untuk semua transaksi yang memiliki rata-rata jumlah transaksi di atas
Rp 100.000 dan diurutkan berdasarkan nama cabang ban dengan kode berikut:
-
SELECT cabang_bank.nama_cabang AS “Nama
Cabang”, transaksi.jenis_transaksi AS “Jenis Transaksi”, AVG(transaksi.jumlah)
AS “Rata-rata (Rp)” FROM transaksi, cabang_bank, rekening GROUP BY
cabang_bank.nama_cabang, transaksi.jenis_transaksi, rekening.kode_cabangFK,
cabang_bank.kode_cabang, transaksi.no_rekeningFK, rekening.no_rekening HAVING
rekening.kode_cabangFK=cabang_bank.kode_cabang AND
transaksi.no_rekeningFK=rekening.no_rekening AND AVG(transaksi.jumlah) >
100000 ORDER BY cabang_bank.nama_cabang;
5. Tampilkan
nama nasabah dan banyaknya transaksi yang telah dilayani oleh Bank Rut Unit
Surakarta dari 15 November 2009 sampai 1 Desember 2009 dan diurutkan
berdasarkan nama nasabah dengan kode berikut:
-
SELECT nasabah.nama_nasabah AS “Nama
Nasabah”, COUNT(transaksi.jumlah) AS “Jumlah Transaksi” FROM transaksi,
cabang_bank, rekening, nasabah WHERE
rekening.kode_cabangFK=cabang_bank.kode_cabang AND
transaksi.no_rekeningFK=rekening.no_rekening AND transaksi.id_nasabahFK=nasabah.id_nasabah
AND transaksi.tanggal BETWEEN ‘2009-11-15’ AND ‘2009-12-1’ AND
cabang_bank.nama_cabang=’Bank Rut Unit Surakarta’ GROUP BY nasabah.nama_nasabah
ORDER BY nasabah.nama_nasabah;
E.
Analisa
Dari praktikum di atas, dapat saya tarik kesimpulan
bahwa untuk menampilkan record-record tertentu ada beberapa alternatif perintah
yang digunakan. Jadi, kita bisa memilih perintah mana yang akan digunakan
tergantung kebutuhan dan efektivitas.
F.
Tugas
1. Tampilkan
jumlah transaksi yang ditangani oleh masing-masing cabang bank!
2. Tampilkan
nama nasabah dan jumlah saldo yang memiliki saldo antara Rp 500.000 sampai Rp
2.000.000!
3. Tampilkan
nama nasabah, tanggal transaksi, dan jumlah transaksi dalam Rp di mana jumlah
transaksi di atas Rp 100.000 dan urutkan berdasarkan jumlah transaksi dari yang
besar ke yang kecil!