PERANCANGAN BASIS DATA PENGOLAHAN NILAI
Diajukan untuk memenuhi tugas Mata Pelajaran Basis Data
DISUSUN OLEH
NAMA SISWA
NIS. 09101XXXXX
KELAS XI…./RPL
KOMPETENSI KEAHLIAN RPL
SEKOLAH MENENGAH KEJURUAN NEGERI 4 BANDUNG
BANDUNG
2010
1. KASUS PERANCANGAN BASIS DATA Perancangan basis data pengolahan nilai (school)
2. ENTITAS
3. ATRIBUT
4. MENGHUBUNGKAN ANTAR ENTITAS (ERD)
Catatan : ERD diatas belum selesai…silahkan dikembangkan ! ☺☺☺☺
siswa jurusan predikat
mata pelajaran
nilai semester
siswa
nis nama ttl
jurusan
kd_jurusan nm_jurusan
mata pelajaran
kd_mapel
nm_mapel
siswa
nis nama ttl
mata pelajaran
kd_mapel
nm_mapel
mengambil
memiliki
jurusan
kd_jurusan nm_jurusan
semester
Kd_sem
sem
thn_ajaran
predikat
nilai
angka
predikat
5. TRANSFORMASI KE TABLE DATABASE
Aturan umum dalam pemetaan model data yang digambarkan dengan ER menjadi basis data fisik (level fisik dlm abstraksi data).
Contoh :
nis nama ttl ………..
6. NORMALISASI
- Tahap 1 : Unnormalisasi (Belum dinormalisasi)
nis nama jurusan thn_ajaran semester kd_mapel nama_mapel nilai predikat 506001 Mario
Sistem
Informasi 2005/2006 Ganjil M02 Matematika A
Baik sekali
Genap F01 Fisika A
Baik sekali 506002
Eko Saputra
Sistem
Informasi 2005/2006 Ganjil M02 Matematika C Cukup
B03 Biologi E Gagal
Genap F01 Fisika D Kurang
K04 Kimia E Gagal
- Tahap 2 : 1 NF (Normalisasi 1)
nis nama jurusan thn_ajaran semester kd_mapel nama_mapel nilai predikat 506001 Mario
Sistem
Informasi 2005/2006 Ganjil M02 Matematika A
Baik sekali 506001 Mario
Sistem
Informasi 2005/2006 Genap F01 Fisika A
Baik sekali 506002
Eko Saputra
Sistem
Informasi 2005/2006 Ganjil M02 Matematika C Cukup 506002 Eko
Saputra
Sistem Informasi
2005/2006
Ganjil B03 Biologi E Gagal
506002 Eko Saputra
Sistem Informasi
2005/2006
Genap F01 Fisika D Kurang
506002 Eko Saputra
Sistem Informasi
2005/2006
Genap K04 Kimia E Gagal
siswa
nis nama ttl
- Tahap 3 : 2 NF (Normalisasi 2) Table siswa :
nis nama kd_mapel nama_mapel nilai kiteria kd_jurusan kd_sem 50600
1 Mario M02 Matematika A Baik sekali SI002 20051
50600
1 Mario F01 Fisika A Baik sekali SI002 20052
50600 2
Eko
Saputra M02 Matematika C Cukup SI002 20051
50600 3
Eko
Saputra B03 Biologi E Gagal SI002 20052
50600 4
Eko
Saputra F01 Fisika D Kurang SI002 20051
50600 5
Eko
Saputra K04 Kimia E Gagal SI002 20051
Tabel jurusan :
Kd_Jurusan Jurusan
TI001 Teknik Informatika SI002 Sistem Informasi
Table semester :
kd_sem semester thn_ajaran 20051 Ganjil 2005/2006 20052 Genap 2005/2006
- Tahap 4 : 3 NF (Normalisasi 3) Tabel siswa :
nis* nama kd_jurusan
506001 Mario TI001
506002 Eko Saputra TI001
506003 Achmad SI002
506004 Budi Santoso SI002
Table jurusan : kd_jurusan* jurusan TI001
Teknik Informatika SI002 Sistem Informasi
Table mapel :
kd_mapel* nama_mapel F01 Fisika
M02 Matematika
B03 Biologi
K04 Kimia
Table semester :
kd_sem* semester thn_ajaran 20051 Ganjil 2005/2006 20052 Genap 2005/2006
Tabel predikat :
nilai* angka predikat
A 5 Baik sekali
B 4 Baik
C 3 Cukup
D 2 Kurang
E 1 Gagal
Tabel ambil :
nis kd_mapel
506001 M02 506001 F01 506002 M02 506002 B03 506002 F01 506002 K04 506003 M02 506003 F01 506004 M02 506004 B03 506004 F01 506004 K04
Tabel nilai :
nis kd_mapel nilai kd_sem
506001 M02 A 20051
506001 F01 A 20051
506002 M02 C 20051
506002 B03 E 20051
506002 F01 D 20052
506002 K04 E 20052
506003 M02 B 20051
506003 F01 C 20051
506004 M02 D 20051
506004 B03 E 20051
506004 F01 D 20052
506004 K04 C 20052
7. MEMBUAT STRUKTUR TABEL Tabel Jurusan
Field Name Tipe Data Field Size Keterangan
kd_jurusan Text 5 Primary Key
jurusan Text 20 Nama jurusan
Tabel Siswa
Field Name Tipe Data Field Size Keterangan
nis
nama
kd_jurusan
Tabel Matapelajaran
Field Name Tipe Data Field Size Keterangan
kd_mapel
nama_mapel
Tabel Semester
Field Name Tipe Data Field Size Keterangan
kd_sem
semester
thn_ajaran
Tabel Predikat
Field Name Tipe Data Field Size Keterangan
nilai
angka
predikat
Tabel Ambil
Field Name Tipe Data Field Size Keterangan
nis
kd_mapel
Tabel Nilai
Field Name Tipe Data Field Size Keterangan
nis
kd_mapel
nilai
kd_sem
8. IMPLEMENTASIKAN KE SEBUAH DATABASE (DBMS) Misal : disini DBMS yang di pakai yaitu MS. Office Access 2007 a. Membuat database school :
create database school;
b. Membuat tabel-tabelnya :
- Perintah SQL untuk membuat tabel jurusan :
create table jurusan(kd_jurusan text(5), jurusan text(20), primary key(kd_jurusan));
- Perintah SQL untuk membuat tabel siswa :
create table siswa(nis text(7), nama text(30), kd_jurusan text(5), primary key(nis));
- Perintah SQL untuk membuat tabel mapel :
create table mapel…… teruskan perintahnya !
- Perintah SQL untuk membuat tabel semester :
create table semester... teruskan perintahnya !
- Perintah SQL untuk membuat tabel ambil :
create table ambil…… teruskan perintahnya !
- Perintah SQL untuk membuat tabel predikat :
create table predikat…… teruskan perintahnya !
- Perintah SQL untuk membuat table nilai :
create table nilai……teruskan perintahnya !
- Keterhubungan Antar Tabel (Relationship)
9. PENGUJIAN BASIS DATA
Dalam pengujian basis data ini dilakukan untuk mengetes tabel-tabel yang sudah kita normalisasi apakah sudah normal atau belum. Untuk itu kita mesti mengonsep dulu kebutuhan informasi dari database yang kita buat itu. Tentunya rencana informasi yang akan ditampilkan adalah tidak keluar dari cakupan database yang kita buat. Contohnya sbb :
a. Kebutuhan Informasi :
1. Menampilkan informasi nilai semester 1 dan 2 tahun ajaran 2005-2006 untuk siswa yang bernama Eko Saputra (nis : 506002)
nis nama nama_mp nilai kd_smt
… Eko Saputra … … …
2. Menampilkan informasi daftar nilai untuk siswa jurusan Teknik Informatika TA 2005- 2006
nis nama jurusan nama_mp nilai thn_ajaran
… … Teknik
Informatika … … …
b. Perintah SQL :
1. Perintah SQL untuk kebutuhan informasi 1 (Menampilkan informasi nilai semester 1 dan 2 tahun ajaran 2005-2006 untuk siswa yang bernama Eko Saputra (nis : 506002)):
SELECT siswa.nis, siswa.nama, mapel.nama_mp, nilai_mp.nilai, nilai_mp.kd_smt
FROM siswa INNER JOIN (mapel INNER JOIN nilai_mp ON
mapel.kode_mp = nilai_mp.kd_mp) ON siswa.nis = nilai_mp.nis WHERE (((siswa.nis)="506002"));
2. Perintah SQL untuk kebutuhan informasi 2 (Menampilkan informasi daftar nilai untuk siswa jurusan Teknik Informatika TA 2005-2006):
SELECT siswa.nis, siswa.nama, jurusan.jurusan, mapel.nama_mp, nilai_mp.nilai, smt.thn_ajaran
FROM smt INNER JOIN ((jurusan INNER JOIN siswa ON jurusan.kd_jurusan = siswa.kd_jurusan) INNER JOIN (predikat INNER JOIN ((mapel INNER JOIN ambil ON mapel.kode_mp = ambil.kd_mp) INNER JOIN nilai_mp ON mapel.kode_mp =
nilai_mp.kd_mp) ON predikat.nilai = nilai_mp.nilai) ON (siswa.nis = nilai_mp.nis) AND (siswa.nis = ambil.nis)) ON smt.kd_smt = nilai_mp.kd_smt
WHERE (((jurusan.jurusan)="Teknik Informatika"));
c. Hasil Pengujian :
1. Hasil Pengujian untuk kebutuhan informasi 1 :
2. Hasil Pengujian untuk kebutuhan informasi 2 :
===== Selamat Mencoba, Semoga bermanfaat ☺☺☺☺ =====
DAFTAR PUSTAKA Yakub. 2008. Sistem Basis Data. Yogyakarta : Graha Ilmu http://www.ilmukomputer.org