Friday, October 4, 2013

Teori dan Tahapan Pembuatan ERD

A. Teori
Entity Relationship Diagram (ERD) merupakan diagram yang digunakan untuk merancang suatu basis data, untuk memperlihatkan hubungan atau relasi antar entitas atau objek yang terlihat beserta atributnya. Objek utama dari pembuatan diagram ERD  menunjukan objek objek (himpunan entitas) apa saja yang ingin dilibatkan dalam sebuah basis data dan bagaimana hubungan yang terjadi antara objek-objek tersebut. 
            ERD pertama kali dideskripsikan oleh Peter Chen yang dibuat sebagai bagian dari perangkat lunak CASE. 
Notasi yang digunakan dalam ERD adalah:
Entitas dapat merupakan :

·         Sebuah elemen lingkungan dari perusahaan , seperti customer atau supplier
·         Suatu sumber daya , seperti suatu piutang dagang, suatu  produk, atau suatu penjual
·         Suatu arus informasi , seperti suatu penjualan pemesanan atau suatu faktur  
          Di dalam sebuah entitas terdapat beberapa atribut. Atribut merupakan gambaran karakteristik dari sebuah entitas atau himpunan entitas.
Contoh : atribut untuk himpunan entitas mahasiswa adalah nim (PK), nama, program studi.
 Penggunaan key merupakan cara untuk membedakan suatu entitas didalam himpunan entitas dengan entitas lain. Key dipilih karena unik, untuk setiap entitas sehingga bisa di bedakan dari entitas yang lain. Kita bisa mendefinisikan key sebagai satu atau gabungan dari beberapa atribut yang dapat membedakan semua row dalam relasi secara unik.
Ada 3 macam key :
1. Super Key
Superkey yaitu satu atau lebih atribut (kumpulan atribut) yang dapat membedakan satiap baris data dalam sebuah relasi secara unik.
Contoh super key yaitu =
1. Nim, nama, alamat, kota
2. Nim, nama, alamat
3. Nim, nama
4. Nim 
2.   Candidat Key
Kumpulan atribut minimal yang dapat membedakan setiap baris data dalam sebuah relasi secara unik
Contoh : Nim
3.   Primary Key
Primary key merupakan salah satu dari candidate key yang terpilih. Alasan pemilihan primary key :
1.   Lebih sering di jadikan acuan
2.   Lebih ringkas
3.   Jaminan keunikan key lebih baik
Contoh dari primary key adalah Nim.
  
Jika sebuah primary key terhubung ke table/entity lain, maka keberadaan primary key pada entity tersebut di sebut sebagai foreign key ( kunci tamu ). 
Misal : Primary Key Kode Dosen dari entity Dosen digunakan juga pada field entity KRS, maka keberadaan field Kode Dosen pada entity KRS disebut sebagai foreign key
        Dalam ERD, hubungan (relasi) dapat terdiri dari sejumlah entitas yang disebut dengan derajad relasi. Derajad relasi maksimum disebut dengan kardinalitas sedangkan derajad minimum disebut dengan modalitas. Jadi kardinalitas relasi menunjukkan jumlah maksimum entitas yang dapat berelasi dengan entitas pada himpunan entitas lain. Kardinalitas relasi yang terjadi diantara dua himpunan entitas (misalnya A dan B) dapat berupa :
1. Satu ke satu (one to one/ 1-1)
Setiap entitas pada himpunan entitas A dapat berelasi dengan paling banyak satu entitas pada himpunan entitas B, demikian juga sebaliknya.
 
2. Satu ke banyak (one to many/ 1- N ) / N-1
Setiap entitas pada himpunan entitas A dapat berelasi dengan banyak entitas pada himpunan entitas B, tetapi tidak sebaliknya. Atau Setiap entitas pada himpunan entitas A hanya dapat berelasi dengan satu entitas pada himpunan entitas B, tetapi tidak sebaliknya.

3. Banyak ke banyak (many to many/ N –N)
Setiap entitas pada himpunan entitas A dapat berelasi dengan banyak entitas pada himpunan entitas B, demikian juga sebaliknya.
B. Tahapan Pembuatan ERD 
Berikut ini adalah contoh tahapan dalam pembuatan ERD pada " Sistem Informasi Akademis " .
Tahap 1: Penentuan Entities

Keterangan :
Mahasiswa:
nim: nomor induk mahasiswa (integer) PK
nama_mhs: nama lengkap mahasiswa (string)
alamat_mhs: alamat lengkap mahasiswa (string)
Dosen:
nip: nomor induk pegawai (integer) PK
nama_dosen: nama lengkap dosen (string)
alamat_dosen: alamat lengkap dosen (string)
Mata_kuliah:
kode_mk: kode untuk mata kuliah (integer) PK
nama_mk: nama lengkap mata kuliah (string)
deskripsi_mk: deskripsi singkat mengenai mata kuliah (string)
Ruang:
kode_ruang: kode untuk ruang kelas (string) PK
lokasi_ruang: deskripsi singkat mengenai lokasi ruang kelas (string)
kapasitas_ruang: banyaknya mahasiswa yang dapat ditampung (integer)
Tahap 2 : Penentuan Atribut
Tahap 3 : Penentuan Kardinalitas Relasi



Hubungan : 
a.  ruang digunakan untuk mata_kuliah:
     · Tabel utama: ruang
     · Tabel kedua: mata_kuliah
     · Relationship: One-to-one (1:1)
     · Attribute penghubung: kode_ruang (FK kode_ruang di mata_kuliah)

b.  dosen mengajar mata_kuliah:
     · Tabel utama: dosen
     · Tabel kedua: mata_kuliah
     · Relationship: One-to-many (1:n) 
     . Attribute penghubung: nip (FK nip di mata_kuliah) 
c.  dosen membimbing mahasiswa:
     . Tabel utama: dosen
     · Tabel kedua: mahasiswa
     . Relationship: One-to-many (1:n)
     . Attribute penghubung: nip (FK nip di mahasiswa)
d.  mahasiswa mengambil mata_kuliah:
    · Tabel utama: mahasiswa, mata_kuliah
    · Tabel kedua: mhs_ambil_mk
    · Relationship: Many-to-many (m:n)
    · Attribute penghubung: nim, kode_mk (FK nim, kode_mk di mhs_ambil_mk)

  Tahap 4 : Pembuaatan ERD



EER (Enhanced Entity Relationship) Diagram:

 
Relasi many to many antar entity perlu dihilangkan dengan cara menambah atribut baru antara 2 entity yang memiliki relasi many to many. Pada diagram diatas, terdapat relasi mahasiswa mengambil matakuliah dimana mempunyai kardinalitas many to many. Maka dari itu perlu dibuat satu entity baru yang didalamnya menampung primary key dari entity mahasiswa dan entity mata kuliah yang nantinya dapat dijadikan foreign key pada entity mhs_ambl_mk , sedang yang dijadikan primary key disini kita ambil password portal akademik yang sifatnya unik ( satu mahasiswa mempunyai password yang berbeda dengan mahasiswa lain ) .

No comments:

Post a Comment