Contoh Perancangan Basis Data Pengolahan Nilai


1. KASUS PERANCANGAN BASIS DATA

Perancangan basis data pengolahan nilai (school)

2. ENTITAS


3. ATRIBUT

atribut

4. MENGHUBUNGKAN ANTAR ENTITAS (ERD)

erd
Catatan : ERD diatas belum selesai…silahkan dikembangkan ! 😀

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 (hanya 1), tabel lainnya di coba sendiri 😀  :

transformasi

6. NORMALISASI

– Dokumen dasar yang akan dinormalisasi :

khs


– 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

– Tahap 3 : 2 NF (Normalisasi 2)

Table siswa :

nis nama kd_mapel nama_mapel nilai kiteria kd_jurusan kd_sem
506001 Mario M02 Matematika A Baik sekali SI002 20051
506001 Mario F01 Fisika A Baik sekali SI002 20052
506002 Eko Saputra M02 Matematika C Cukup SI002 20051
506003 Eko Saputra B03 Biologi E Gagal SI002 20052
506004 Eko Saputra F01 Fisika D Kurang SI002 20051
506005 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));

tjurusan

– Perintah SQL untuk membuat tabel siswa :

create table siswa(nis text(7), nama text(30), kd_jurusan text(5), primary key(nis));

tsiswa

– 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)

relationshiptable


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 :

uji_1

2. Hasil Pengujian untuk kebutuhan informasi 2 :

uji_2

Untuk baca selengkapnya…silahkan klik file di bawah!

CONTOH TUGAS PBD SCHOOL

===== Selamat Mencoba, Semoga bermanfaat 🙂 =====


DAFTAR PUSTAKA

Yakub. 2008. Sistem Basis Data. Yogyakarta : Graha Ilmu

http://www.ilmukomputer.org

About jauharulali

Kita tak akan pernah tahu siapa diri kita, sampai kita dpt melihat apa yg bisa kita lakukan

Posted on 29 Agustus 2010, in Basis Data, Programming, TIK. Bookmark the permalink. 14 Komentar.

  1. Terimakasih ! Saya Sangat Terbantu Dengan ini, Terus Maju ! ” =D

  2. thankz y infonya…..sngat membantu saya buat nyelelesaikan tugas saya….
    semoga makin sukses lg….:)

  3. Thanks ea..tas infonya..dngan ini saya sngat terbantu.tuk menyelesaikan tugas saya….:D

  4. Mksih buat infonya.. 🙂
    bener” ngebantu bnget… 😀

  5. Zulyadi Suhendra

    akhirnya dapat juga belajar dengan wap

    Makasih ya mas atas berbagi ilmunya

  6. wah mantep…cocok ni referensi dengan yang saya cari..makasi gan

  7. saya mau bertanya bagaimana dengan nanti jika ada nis,kd_mapel,kd_semester yang duplikat di tbl_nilai ? terima kasih

  8. stefani lidyawati

    thanks very nice

  9. makasih sangat membantu

Tinggalkan komentar