A. Tujuan
Mahasiswa mampu menggunakan select statements besertaoptions-nya untuk mencari, mengolah, dan menampilkan data yang ada di basis data sesuai dengan kebutuhannya.
B. Dasar Teori
• IN
Contoh:
SELECT* FROM rekening WHERE kode_cabang IN (‘BRUM’, ‘BRUL’);
• NOT IN
Contoh:
SELECT* FROM rekening WHERE kode_cabang NOT IN (‘BRUS’, ‘BRUM’);
• BETWEEN
Contoh:
SELECT* FROM rekening WHERE saldo BETWEEN 500000 AND 1000000;
• NOT BETWEEN
Contoh:
SELECT* FROM rekening WHERE saldo NOT BETWEEN 500000 AND 1000000;
• AGGREGATE FUNCTIONS
Fungsi-fungsi untuk aggregate:
• MIN( )
Digunakan untuk mencari nilai terkecil dari sekumpulan record.
Contoh:
SELECT MIN(saldo) FROM rekening;
• MAX( )
Digunakan untuk mencari nilai terbesar dari sekumpulan record.
Contoh:
SELECT MAX(saldo) FROM rekening;
• COUNT( )
Digunakan untuk menghitung banyaknya record.
Contoh:
SELECT COUNT(nama_nasabah) FROM nasabah;
• SUM( )
Digunakan untuk menjumlahkan nilai-nilai dari sekumpulanrecord.
Contoh:
SELECT SUM(saldo) FROM rekening;
• AVG( )
Digunakan untuk menghitung rata-rata nilai dari sekumpulanrecord.
Contoh:
SELECT AVG(saldo) FROM rekening;
• GROUP BY
Digunakan untuk mengelompokkan sekumpulan recordberdasarkan (kolom-kolom) tertentu.
Contoh:
SELECT jenis_transaksi FROM transaksi GROUP BY jenis_transaksi;
• HAVING
Merupakan pasangan dari GROUP BY, digunakan untuk membatasi kelompok yang ditampilkan:
SELECT jenis_transaksi, tanggal FROM transaski GROUP BY jenis_transaksi, tanggal HAVING jenis_transaksi=’kredit’;
• 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.
Contoh:
SELECT kode_cabang, MIN(saldo), MAX(saldo), COUNT(*), SUM(saldo), AVG(saldo) FROM rekening GROUP BY kode_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:
Mahasiswa mampu menggunakan select statements besertaoptions-nya untuk mencari, mengolah, dan menampilkan data yang ada di basis data sesuai dengan kebutuhannya.
B. Dasar Teori
• IN
Contoh:
SELECT* FROM rekening WHERE kode_cabang IN (‘BRUM’, ‘BRUL’);
• NOT IN
Contoh:
SELECT* FROM rekening WHERE kode_cabang NOT IN (‘BRUS’, ‘BRUM’);
• BETWEEN
Contoh:
SELECT* FROM rekening WHERE saldo BETWEEN 500000 AND 1000000;
• NOT BETWEEN
Contoh:
SELECT* FROM rekening WHERE saldo NOT BETWEEN 500000 AND 1000000;
• AGGREGATE FUNCTIONS
Fungsi-fungsi untuk aggregate:
• MIN( )
Digunakan untuk mencari nilai terkecil dari sekumpulan record.
Contoh:
SELECT MIN(saldo) FROM rekening;
• MAX( )
Digunakan untuk mencari nilai terbesar dari sekumpulan record.
Contoh:
SELECT MAX(saldo) FROM rekening;
• COUNT( )
Digunakan untuk menghitung banyaknya record.
Contoh:
SELECT COUNT(nama_nasabah) FROM nasabah;
• SUM( )
Digunakan untuk menjumlahkan nilai-nilai dari sekumpulanrecord.
Contoh:
SELECT SUM(saldo) FROM rekening;
• AVG( )
Digunakan untuk menghitung rata-rata nilai dari sekumpulanrecord.
Contoh:
SELECT AVG(saldo) FROM rekening;
• GROUP BY
Digunakan untuk mengelompokkan sekumpulan recordberdasarkan (kolom-kolom) tertentu.
Contoh:
SELECT jenis_transaksi FROM transaksi GROUP BY jenis_transaksi;
• HAVING
Merupakan pasangan dari GROUP BY, digunakan untuk membatasi kelompok yang ditampilkan:
SELECT jenis_transaksi, tanggal FROM transaski GROUP BY jenis_transaksi, tanggal HAVING jenis_transaksi=’kredit’;
• 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.
Contoh:
SELECT kode_cabang, MIN(saldo), MAX(saldo), COUNT(*), SUM(saldo), AVG(saldo) FROM rekening GROUP BY kode_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 n.nama_nasabah as "Nama
  Nasabah",t.jenis_transaksi as "Jenis Transaksi", 
AVG(t.jumlah) as "Rata-rata (Rp.)" from transaksi
  t,nasabah n where n.id_nasabah= 
t.id_nasabahfk group by n.nama_nasabah, t.jenis_transaksi order
  by "Rata-rata (Rp.)";*/ | 
 maka akan tampil gambar dibawah ini :
| 
/*select n.nama_nasabah as "Nama
  Nasabah",t.jenis_transaksi as "Jenis Transaksi", 
COUNT(t.jumlah) as "Jumlah Transaksi", SUM(t.jumlah) as
  "Jumlah (Rp.)" from  
transaksi t,nasabah n where n.id_nasabah=t.id_nasabahfk group by
  n.nama_nasabah, t.jenis_transaksi order by "Jumlah Transaksi"
  desc;*/ | 
 maka akan tampil gambar dibawah ini :
| 
/*select c.nama_cabang as "Nama
  Cabang",t.jenis_transaksi as "Jenis Transaksi",SUM(t.jumlah) as
  "Jumlah (Rp.)",COUNT(t.jumlah) as "Jumlah Transaksi" from
  transaksi t, cabang_bank c,rekening r where c.kode_cabang=r.kode_cabangfk and
  r.no_rekening=t.no_rekeningfk group by c.nama_cabang, t.jenis_transaksi order
  by c.nama_cabang,t.jenis_transaksi;*/ | 
 maka akan tampil gambar dibawah ini :
| 
/*select c.nama_cabang as "Nama Cabang",t.jenis_transaksi
  as "Jenis Transaksi",AVG(t.jumlah) as "Rata-rata (Rp.)" from
  transaksi t, cabang_bank c,rekening r group by c.nama_cabang,t.jenis_transaksi,
  r.kode_cabangfk,c.kode_cabang, 
t.no_rekeningfk,r.no_rekening HAVING r.kode_cabangfk=c.kode_cabang
  and t.no_rekeningfk=r.no_rekening and AVG(t.jumlah)> 100000 order by
  c.nama_cabang;*/ | 
 maka akan tampil gambar dibawah ini :
  
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 n.nama_nasabah as "Nama
  Nasabah",COUNT(t.jumlah) as "Jumlah Transaksi" from  
transaksi t,cabang_bank c,rekening r,nasabah n where
  r.kode_cabangfk=c.kode_cabang and 
t.no_rekeningfk=r.no_rekening and t.id_nasabahfk=n.id_nasabah and
  t.tanggal between '2009-11-15' and '2009-12-1' and c.nama_cabang='bank rut
  unit surakarta' group by n.nama_nasabah order by n.nama_nasabah;*/ | 
 maka akan tampil gambar dibawah ini :
E. Analisa
Dari praktikum tersebut, dapat saya simpulan bahwa menampilkan record-record tertentu ada beberapa alternatif perintah yang digunakan. Jadi, kita bisa memilih perintah mana yang akan digunakan tergantung kebutuhan dan efektivitas.
Dari praktikum tersebut, dapat saya simpulan bahwa 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!
| 
/*select c.nama_cabang, COUNT(t.jumlah) as "Jumlah
  Transaksi" from transaksi t,cabang_bank c,rekening r  where c.kode_cabang=r.kode_cabangfk and
  r.no_rekening=t.no_rekeningfk group by c.nama_cabang order by
  c.nama_cabang;*/ | 
 maka akan tampil gambar dibawah ini :
| 
/*select n.nama_nasabah, SUM(r.saldo) as "Jumlah Saldo
  (Rp.)"  from nasabah n, rekening
  r, nasabah_has_rekening nr where n.id_nasabah=nr.id_nasabahfk and r.no_rekening=nr.no_rekeningfk
  and r.saldo between 500000 and 2000000  group by n.nama_nasabah order by
  n.nama_nasabah;*/ | 
 maka akan tampil gambar dibawah ini :
| 
/*select n.nama_nasabah, t.tanggal, SUM(t.jumlah) as "Jumlah
  (Rp.)" from nasabah n, transaksi t group by n.nama_nasabah,t.tanggal,t.jumlah,t.id_nasabahfk,n.id_nasabah 
HAVING t.id_nasabahfk=n.id_nasabah and SUM(t.jumlah) > 100000  order by "Jumlah (Rp.)" desc;*/ | 
 maka akan tampil gambar dibawah ini :








No comments:
Post a Comment