Contoh Sederhana Perancangan Basis Data
1. KASUS
PERANCANGAN BASIS DATA
Perancangan
basis data pengolahan nilai (school)
2. ENTITAS
3. ATRIBUT
Catatan : ERD diatas belum selesai…silahkan dikembangkan ! :D
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 :D :
6.
NORMALISASI
- Dokumen
dasar yang akan dinormalisasi :
– Tahap 1 :
Unnormalisasi (Belum dinormalisasi)
nis
|
nama
|
jurusan
|
thn_ajaran
|
semester
|
kd_mapel
|
nama_mapel
|
nilai
|
predikat
|
506001
|
Mario
|
Sistem
Informasi
|
2013/2014
|
Ganjil
|
M02
|
Matematika
|
A
|
Baik
sekali
|
Genap
|
F01
|
Fisika
|
A
|
Baik
sekali
|
||||
506002
|
Eko
Saputra
|
Sistem
Informasi
|
2013/2014
|
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
|
2013/2014
|
Ganjil
|
M02
|
Matematika
|
A
|
Baik
sekali
|
506001
|
Mario
|
Sistem
Informasi
|
2013/2014
|
Genap
|
F01
|
Fisika
|
A
|
Baik
sekali
|
506002
|
Eko
Saputra
|
Sistem
Informasi
|
2013/2014
|
Ganjil
|
M02
|
Matematika
|
C
|
Cukup
|
506002
|
Eko
Saputra
|
Sistem
Informasi
|
2013/2014
|
Ganjil
|
B03
|
Biologi
|
E
|
Gagal
|
506002
|
Eko
Saputra
|
Sistem
Informasi
|
2013/2014
|
Genap
|
F01
|
Fisika
|
D
|
Kurang
|
506002
|
Eko
Saputra
|
Sistem
Informasi
|
2013/2014
|
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
|
2013/2014
|
20052
|
Genap
|
2013/2014
|
– 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
|
2013/2014 |
20052
|
Genap
|
2013/2014
|
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 2013/2014 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 2013-2014
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 2013/2014 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 2013/2014):
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 = = =
0 komentar:
Posting Komentar