Langsung ke konten utama

FOREIGN KEY - Constraint

 Penjelasan 

Foreign key pada database adalah kolom atau sekelompok kolom dalam sebuah tabel yang mereferensikan primary key atau unique key di tabel lain. Foreign key digunakan untuk membangun hubungan antara dua tabel dalam database relasional.

Dalam hubungan antar tabel, tabel yang mereferensikan primary key atau unique key disebut sebagai tabel anak (child table) dan tabel yang menjadi rujukan disebut sebagai tabel induk (parent table). Kolom foreign key pada tabel anak menunjukkan bahwa nilai pada kolom tersebut berasal dari nilai pada primary key atau unique key di tabel induk.

Contoh penggunaan foreign key pada tabel "siswa" dan "kelas":

CREATE TABLE kelas (
  id INT PRIMARY KEY,
  nama_kelas VARCHAR(50),
  tingkat VARCHAR(10)
);

CREATE TABLE siswa (
  id INT PRIMARY KEY,
  nama VARCHAR(50),
  id_kelas INT,
  umur INT,
  FOREIGN KEY (id_kelas) REFERENCES kelas(id)
);

Dalam contoh di atas, kolom "id_kelas" pada tabel "siswa" merupakan foreign key yang mereferensikan kolom "id" pada tabel "kelas". Dengan menggunakan foreign key ini, kita dapat membangun hubungan antara tabel "siswa" dan "kelas". Setiap nilai pada kolom "id_kelas" pada tabel "siswa" harus sesuai dengan nilai pada kolom "id" pada tabel "kelas".

Fungsi FOREIGN KEY

Beberapa fungsi penting dari foreign key pada database antara lain:
  • Membentuk hubungan antar tabel: Dengan menggunakan foreign key, kita dapat membangun hubungan antar tabel dalam database relasional, sehingga memudahkan dalam mengakses dan mengolah data.
  • Memastikan integritas data: Dengan menggunakan foreign key, kita dapat memastikan integritas data dalam database, karena setiap nilai pada kolom foreign key harus sesuai dengan nilai pada kolom primary key atau unique key di tabel lain.
  • Melindungi data dari perubahan atau penghapusan yang tidak diinginkan: Jika ada perubahan atau penghapusan data pada tabel yang memiliki hubungan dengan tabel lain melalui foreign key, database akan memberikan peringatan atau error agar kita dapat memperbaiki atau membatalkan operasi tersebut, sehingga melindungi data dari perubahan atau penghapusan yang tidak diinginkan.
  • Mengoptimalkan kinerja database: Dengan menggunakan foreign key, kita dapat mempercepat operasi database seperti pencarian dan pengambilan data, karena kita dapat melakukan join antar tabel yang terhubung melalui foreign key.

Komentar

Postingan populer dari blog ini

Boolean - Data Types SQL

 Penjelasan Tipe data boolean pada database adalah tipe data yang memungkinkan penyimpanan nilai kebenaran (true atau false) dalam sebuah tabel database. Penyimpanan nilai boolean dalam sebuah tabel database biasanya dilakukan untuk menyimpan informasi kebenaran dari sebuah kondisi atau status pada suatu data. Misalnya, pada tabel pengguna, kita bisa menambahkan kolom "status" dengan tipe data tinyint untuk menyimpan status aktif/non-aktif pengguna. Jika pengguna aktif, maka nilai statusnya adalah 1 (true), sedangkan jika non-aktif, maka nilai statusnya adalah 0 (false). Dalam bahasa SQL, nilai boolean sering digunakan untuk melakukan pengambilan data berdasarkan kondisi yang diberikan (query). Misalnya, kita bisa menuliskan query untuk menampilkan semua pengguna yang statusnya aktif, yaitu dengan menggunakan perintah SELECT * FROM pengguna WHERE status = 1. Contoh Penggunaan  Berikut adalah contoh penggunaan tipe data BOOLEAN pada SQL: CREATE TABLE students (   student_i...

String - Data Types SQL

 Penjelasan String database adalah tipe data yang digunakan untuk menyimpan data teks pada database. String database dapat digunakan untuk menyimpan berbagai jenis data teks, seperti nama, alamat, teks deskripsi, atau bahkan kode program. Setiap field pada tabel database memiliki tipe data tertentu, termasuk tipe data string. Ketika sebuah record atau baris ditambahkan ke tabel, nilai string database akan disimpan pada field yang sesuai. Berikut adalah 2 contoh penggunaan type data string: Membuat tabel users dengan kolom 'name' dan 'email' yang menggunakan tipe data string: CREATE TABLE users (     id INT(11) NOT NULL AUTO_INCREMENT,     name VARCHAR(255) NOT NULL,     email VARCHAR(255) NOT NULL,     PRIMARY KEY (id) ); Dalam contoh ini, kolom 'name' dan 'email' menggunakan tipe data VARCHAR(255) untuk menyimpan nama dan alamat email pengguna. Memasukkan data ke dalam tabel users: INSERT INTO users (name, email) VALUES ('Kharisya Mer', 'kha...

DCL (Data Control Languange)

 DCL (Data Control Languange) Pengertian DCL Data Control Language (DCL) adalah salah satu dari kelompok perintah SQL yang digunakan untuk melakukan kontrol terhadap privilege atau hak akses khusus untuk berinteraksi dengan database. Hak akses khusus ini diperlukan sebagai prasyarat bagi setiap user database untuk melakukan berbagai aksi di database, seperti: membuat object, menghapus object, mengubah object, menampilkan hasil query, dan seterusnya. Sederhananya, setiap pengguna database hanya dapat melakukan aksi-aksi yang sudah diberikan oleh user dengan kontrol tertinggi di dalam database tersebut. Misalnya, pengguna A hanya diberikan akses untuk membuat dan menampilkan sesuatu di database. Maka, pengguna tersebut hanya dapat melakukan perintah tersebut saja, tidak bisa melakukan ubah data, hapus data, dan seterusnya. Hal ini menjadi penting untuk diketahui karena di dalam dunia kerja dengan banyak pengguna database, manajemen pembagian hak akses seperti ini sangat krusial dan b...