Senin, 10 Desember 2012

►Pembuatan Entity Relationship Diagram (ERD) Studi Kasus : Database Inventori Toko X◄


  • Permasalahan
Toko X adalah sebuah toko dimana gudang untuk menyimpan barang-barangnya lebih dari satu. Data yang dicatatnya adalah supplier yang memasok barang, barang atau produk yang ada dalam toko, nota pembelian yang didapat dari proses pembelian,dan  stok yang ada pada masing-masing gudang. Permasalah yang muncul adalah sulitnya untuk mengecek stok barang pada masing-masing gudang karena jarak sehingga mengakibatkan proses penyimpanan menjadi terhambat.
  • Tahap 1: Penentuan Entities
produk : menyimpan semua informasi mengenai semua produk yang ditawarkan.
pemasok
 : menyimpan semua informasi mengenai semua pemasok.
nota_pembelian
 : menyimpan semua informasi mengenai semua transaksi pembelian produk dari pemasok.
gudang
 : menyimpan semua informasi mengenai gudang untuk penyimpanan produk
  • Tahap 2 : Penentuan Attributes
produk :
-  kode_produk: kode unik untuk tiap macam produk (string) PK.
-  nama_produk: nama lengkap untuk produk (string).
-  harga_jual: harga jual produk di toko (integer)
pemasok:
-  kode_pemasok: kode unik untuk tiap pemasok (string) PK.
-  nama_pemasok: nama lengkap untuk pemasok (string).
-  alamat_pemasok: alamat lengkap untuk pemasok (string)
nota_pembelian:
-  no_nota: kode untuk nota pembelian (integer) PK.
-  tanggal: tanggal transaksi dilakukan (date)
gudang:
-  kode_gudang: kode untuk ruang kelas (string) PK.
-  alamat_gudang: alamat lengkap untuk gudang (string)
  • Tahap 3: Penentuan Relationships
  • Hubungan:
    • produk disimpan di gudang:
    • Tabel utama: produkgudang
    • Tabel kedua: stok_produk
    • Relationship: Many-to-many (m:n)
    • Attribute penghubung: kode_produkkode_gudang (FK kode_produk,kode_gudang di stok_produk)
    • produk tercatat di nota_pembelian:
    • Tabel utama: produknota_pembelian
    • Tabel kedua: rincian_nota_pembelian
    • Relationship: Many-to-many (m:n)
    • Attribute penghubung:  kode_produkno_nota (FK kode_produk,no_nota di rincian_nota_pembelian)
    • pemasok tercatat di nota_pembelian:
    • Tabel utama: pemasok
    • Tabel kedua: nota_pembelian
    • Relationship: One-to-many (1:n).
    • Attribute penghubung:  kode_pemasok (FK kode_pemasok dinota_pembelian)
    • Tahap 4: Pembuatan ERD
    • Implementasi
    CREATE TABLE produk (
    kode_produk varchar(20) PRIMARY KEY,
    nama_produk varchar(45) UNIQUE,
    harga_jual integer
    );
    CREATE TABLE pemasok (
    kode_pemasok varchar(20) PRIMARY KEY,
    nama_pemasok varchar(20) NOT NULL,
    alamat_pemasok varchar(45) NOT NULL,
    CHECK(nama_pemasok!=” AND alamat_pemasok!=”)
    );
    CREATE TABLE gudang (
    kode_gudang varchar(20) PRIMARY KEY,
    alamat_gudang varchar(45)
    );
    CREATE TABLE pembelian (
    no_nota serial PRIMARY KEY,
    kode_pemasok varchar(20) REFERENCES pemasok(kode_pemasok),
    tanggal date DEFAULT current_date
    );
    CREATE TABLE nota_pembelian (
    no_nota serial PRIMARY KEY,
    kode_pemasok varchar(20) REFERENCES pemasok(kode_pemasok),
    tanggal date DEFAULT current_date
    );
    CREATE TABLE rincian_nota_pembelian (
    kode_produk varchar(20) REFERENCES produk(kode_produk),
    no_nota integer REFERENCES nota_pembelian(no_nota),
    harga_satuan integer,
    jumlah integer NOT NULL,
    CHECK(jumlah>=20),
    FOREIGN KEY(kode_produk, no_nota)
    );
    CREATE TABLE stok_produk (
    kode_produk varchar(20) REFERENCES produk(kode_produk),
    kode_gudang varchar(20) REFERENCES gudang(kode_gudang),
    jumlah_stok integer NOT NULL,
    CHECK(jumlah_stok<=200),
    FOREIGN KEY (kode_produk, kode_gudang)
    );

Tidak ada komentar:

Posting Komentar