Membuat Relasi Antar Tabel Pada MySQL

[basis.data|akuntansi|lab.software|pert.13]

Pada pertemuan sebelumnya dibuat satu tabel (tabel barang) dengan MySQL yang dihubungkan dengan form berbasis web (php). Tentu saja setiap basis data akan memiliki lebih dari satu tabel, misalnya tabel yang lain seperti detilpenjualan, penjualan, atau juga suplier. Untuk mudahnya kita buat satu tabel baru yakni tabel detilpenjualan yang terhubung dengan tabel barang. Relasinya kira-kira sebagai berikut:

Membuat Tabel Suplier

Ada dua tabel master yaitu tabel barang dan tabel Suplier. Buat tabel suplier dengan script SQL berikut ini:

  • CREATE TABLE SUPLIER (
  • KdSuplier CHAR(10) NOT NULL,
  • NamaSuplier VARCHAR(20) NOT NULL,
  • Alamat VARCHAR(25) NOT NULL,
  • Kontak CHAR(10),
  • PRIMARY KEY (KdSuplier)
  • );

Jalankan dengan mengklik simbol SQL pada phpmyadmin (http://localhost/phpmyadmin/). Atau bisa juga dengan create lewat menu di phpmyadmin. Masukan satu buah record, misalnya:

  • INSERT INTO SUPLIER (KdSuplier, NamaSuplier, Alamat, Kontak) VALUES
  • (‘S001′,’Rahmadya’,’Bekasi’,’3332211′),
  • (‘S002′,’Ujang’,’Jakarta’,’123456′);

Pastikan kode SQL ketika dijalankan berhasil.

Membuat Tabel Penjualan

Tabel penjualan membutuhkan field-field: KdPenjualan, KdSuplier, dan Total. Sehingga memerlukan Foreign Key KdSuplier yang berasal dari tabel Suplier. Berikut kode SQL-nya:

  • CREATE TABLE PENJUALAN (
  • KdPenjualan INT AUTO_INCREMENT NOT NULL,
  • KdSuplier CHAR(10) NOT NULL,
  • total DECIMAL(8,2) NOT NULL,
  • PRIMARY KEY (KdPenjualan),
  • FOREIGN KEY (KdSuplier) REFERENCES suplier(KdSuplier)
  • ON DELETE CASCADE
  • ON UPDATE CASCADE
  • );

Perhatikan frasa on delete cascade dan on update cascade pada foreign key KdSuplier. Di sini artinya jika kode suplier dihapus atau diedit maka tabel penjualan juga berubah. Tapi jika ingin tidak berubah tidak perlu memasukan frasa tersebut.

Membuat Tabel DetilPenjualan

Tabel ini bermaksud mengakomodir relasi many to many dimana transaksi melibatkan jumlah barang yang lebih dari satu. KdPenjualan dan KdBarang menjadi primary key (komposit). Berikut kode SQL untuk tabel barang dan tabel DetilPenjualan.

  • CREATE TABLE BARANG(
  • KdBarang VARCHAR(10),
  • NamaBarang VARCHAR(25),
  • Harga decimal,
  • PRIMARY KEY (KdBarang)
  • );

Dan untuk tabel DetilPenjualan:

  • CREATE TABLE DETILPENJUALAN (
  • KdPenjualan INT AUTO_INCREMENT NOT NULL,
  • KdBarang CHAR(10) NOT NULL,
  • FOREIGN KEY (KdBarang) REFERENCES barang (KdBarang),
  • PRIMARY KEY (KdPenjualan,KdBarang)
  • );

Perhatikan kode di atas dimana PRIMARY KEY ada dua yaitu KdPenjualan dan KdBarang. Silahkan tambahkan ON DELETE CASCADE atau ON UPDATE CASCADE. Selamat mencoba.

Iklan

Tinggalkan Balasan

Isikan data di bawah atau klik salah satu ikon untuk log in:

Logo WordPress.com

You are commenting using your WordPress.com account. Logout /  Ubah )

Foto Google+

You are commenting using your Google+ account. Logout /  Ubah )

Gambar Twitter

You are commenting using your Twitter account. Logout /  Ubah )

Foto Facebook

You are commenting using your Facebook account. Logout /  Ubah )

Connecting to %s