Media Belajar Bahasa Pemrograman | by APPKEY

SQLTutorial SQL 38 : Memahami SQL Foreign Key

Tutorial SQL 38 : Memahami SQL Foreign Key

-

Last Updated on January 19, 2023 by

SQL Foreign Key adalah sebuah cara untuk menempatkan “relasional” di “database relasional” – Ia membantu menentukan hubungan antar tabel. Foreign Key memungkinkan pengembang untuk mempertahankan integritas referensial di seluruh basis data mereka. Foreign Key juga membantu pengguna akhir dengan mencegah kesalahan dan meningkatkan kinerja operasi apa pun yang menarik data dari tabel yang ditautkan oleh Foreign Key yang diindeks.

Pada tingkat teknis, Foreign Key adalah kendala yang menghubungkan kolom dalam satu tabel ( table_1.column_a) ke kolom dalam tabel yang berbeda ( table_2.column_b) dan memastikan bahwa nilai dapat ditambahkan column_a hanya jika nilai yang sama sudah ada di column_b.

Misalnya, tabel Order mungkin memiliki user kolom dengan atribut Sql Foreign Key yang menautkannya ke kolom Developer di tabel pengguna. Dengan cara ini, setiap baris dalam tabel pesanan dapat dikaitkan dengan pengguna tertentu dari tabel pengguna — dan tidak ada pesanan yang dapat masuk ke sistem tanpa pengguna yang valid dikaitkan dengan mereka.

Bagaimana sebenarnya Foreign Key bekerja dalam praktik? Mari menjadi praktis, dan pelajari lebih lanjut tentang Foreign Key dengan melihat bagaimana fungsinya dalam konteks database SQL sederhana.

Pada artikel ini, kami akan membahas apa itu foreign key, Mengapa Foreign Key penting dalam database relasional, Cara membuat tabel dengan Foreign Key menggunakan SQL, dan Mengontrol bagaimana penghapusan dan pembaruan memengaruhi banyak tabel dengan tindakan Foreign Key.

Apa Itu SQL Foreign Key?

sql foreign key, foreign key adalah

Foreign Key menautkan data dalam satu tabel ke data di tabel lain. Kolom Foreign Key di tabel menunjuk ke kolom dengan nilai unik di tabel lain (biasanya kolom kunci utama) untuk membuat cara mereferensikan silang kedua tabel. Jika kolom diberi Foreign Key, setiap baris kolom itu harus berisi nilai yang ada di kolom ‘foreign’ yang dirujuknya. Kolom yang direferensikan (yaitu “unik”) hanya boleh berisi nilai unik – seringkali ini adalah kunci utama tabelnya.

Artikel Terkait  Tutorial SQL 2 : Perintah SQL, Mengenal Penggunaan Syntax Dasar SQL

Untuk contoh nyata, mari kita lihat lagi table Order berikut ini. Kolom Developer_Id di sini sesuai dengan kolom ID dalam table Developer.

Ini adalah contoh dari tabel “Developer” di database:

ID Name City Country
1 Dion Surabaya Indonesia
2 Celine Jakarta Indonesia
3 Nareswara Malang Indonesia
4 Nuraini Lombok Indonesia
5 Gideon Bogor Indonesia

Berikut ini contoh dari table “order” di database :

Order_ID Client_ID Developer_ID Date
1509 9 1 2023-01-12
1510 20 3 2022-12-20
1511 15 5 2023-01-18

Batasan SQL Foreign Key

Menggunakan Sql Foreign Key ini menyelamatkan kita dari keharusan menyimpan data yang sama berulang kali – kita tidak perlu menyimpan nama pengguna di table order, karena kita bisa menggunakan orders.Developer_ID referensi baris unik pengguna itu Developer.ID untuk mendapatkan nama mereka dan informasi lain tentang mereka.

Tetapi tujuan sebenarnya dari Foreign Key adalah mereka menambahkan batasan: entri ke tabel dengan Foreign Key harus memiliki nilai yang sesuai dengan kolom tabel ‘asing’.

Batasan ini disebut batasan Foreign Key. Mari kita lihat batasan Foreign Key lebih detail.

Batasan Sql Foreign Key adalah aturan yang dibuat saat kita menambahkan Foreign Key ke sebuah tabel. Batasan Foreign Key di tabel A menautkan ke kolom dengan nilai unik di tabel B dan mengatakan bahwa nilai di A kolom hanya valid jika juga ada di B kolom .

Artikel Terkait  Tutorial SQL 42 : Cara Menggunakan SQL Alter Table

(Catatan: Foreign Key bisa berupa kunci gabungan, jadi Foreign Key untuk satu kolom bisa menjadi dua atau lebih kolom di tabel lain. Dalam artikel ini, demi kesederhanaan, kita akan berfokus pada menautkan satu kolom dalam satu tabel ke tabel satu kolom di kolom lain.)

Sebagai contoh, bayangkan kita telah menyiapkan table order kita dengan Foreign Key yang kita susun sebelumnya: orders.Developer_ID references Developer.ID. Aturan-aturan ini berarti bahwa:

Setiap nilai Sql Foreign Key yang dimasukkan orders.Developer_Id harus sudah ada di Developer.ID.

Dengan kata lain, pesanan harus ditempatkan oleh pengguna terdaftar – table order tidak akan menerima baris baru atau pembaruan baris jika nilai di orders.Developer_Id belum ada di Developer.ID.

Bagaimana Menggunakan Foreign Key Pada SQL?

Sekarang setelah kita memahami apa itu foreign key dan bagaimana cara kerjanya, mari kita lihat sekilas bagaimana kita dapat menetapkan nilai ini saat membuat tabel di database kita.

Untuk membuat Tabel Order dari database kami dengan Foreign Key:

My SQL :

CREATE TABLE Orders (

    Order_ID int NOT NULL,

    Developer_ID int,

    PRIMARY KEY (Order_ID),

    FOREIGN KEY (Developer_ID) REFERENCES Developers(ID)

);

SQL Server, MS ACCESS, ORACLE

CREATE TABLE Orders (

    Order_ID int NOT NULL PRIMARY KEY,

    Developer_ID int FOREIGN KEY REFERENCES Developers(ID)

);

Gunakan sintaks SQL ini untuk memungkinkan batasan FOREIGN KEY untuk diberi nama, dan batasan FOREIGN KEY pada berbagai kolom untuk ditentukan:

MySQL / SQL Server / MS Access / Oracle :

CREATE TABLE Orders (

    Order_ID int NOT NULL,

    Developer_ID int,

    PRIMARY KEY (OrderID),

    CONSTRAINT FK_DeveloperOrder FOREIGN KEY (Developer_ID)

    REFERENCES Developers(ID)

);

Pada kode di atas, kita menyetel kolom order_ID sebagai Primary Key, lalu menyetel aturan dalam bentuk batasan Foreign Key untuk Kolom lainnya:

Artikel Terkait  Tutorial SQL 44: SQL Create Table & Contoh Penggunaannya!

Developer_ID memiliki Developer.ID Foreign Keynya (yaitu nilai apapun di orders.Developer_ID harus sudah ada di Developer.ID).

Cara menangani pembaruan, penghapusan, dan lainnya dengan Foreign Key

Sql Foreign Key memberi kita kekuatan untuk menentukan hubungan antara dua tabel atau lebih. Ini bagus, tetapi ini berarti bahwa kita perlu memikirkan dengan hati-hati tentang apa yang terjadi ketika nilai yang ditautkan ke seluruh tabel diubah atau dihapus.

Misalnya, salah satu Developer bernama Gideon, meminta kami menghapus akunnya dan semua data yang terkait dengannya. Kami dapat menjalankan kueri berikut untuk menghapusnya dari Tabel Developer :

DELETE FROM Developer WHERE ID = 5;

SQL FOREIGN KEY pada ALTER TABLE

Gunakan sintaks SQL ini untuk membuat batasan FOREIGN KEY pada kolom “Developer_ID” saat tabel “Order” sudah ada:

MySQL / SQL Server / MS Access / Oracle:

Contoh

ALTER TABLE Orders

ADD FOREIGN KEY (Developer_ID) REFERENCES Developers(ID);

Gunakan sintaks SQL ini untuk memungkinkan batasan FOREIGN KEY untuk diberi nama, dan batasan FOREIGN KEY pada berbagai kolom untuk ditentukan:

MySQL / SQL Server / MS Access / Oracle:

Contoh

ALTER TABLE Orders

ADD CONSTRAINT FK_DeveloperOrder

FOREIGN KEY (Developer_ID) REFERENCES Developers(ID);

Untuk DROP Batasan FOREIGN KEY

Gunakan sintaks SQL ini, untuk menghilangkan batasan FOREIGN KEY.

MySQL:

Contoh

ALTER TABLE Orders

DROP FOREIGN KEY FK_DeveloperOrder;

SQL Server/MS Access/Oracle:

Contoh

ALTER TABLE Orders

DROP CONSTRAINT FK_DeveloperOrder;

Temukan lebih banyak artikel seri belajar SQL maupun bahasa pemrograman lainnya hanya di CODEKEY. Klik https://codekey.id/ sekarang juga untuk langsung belajar gratis. Sampai bertemu lagi!


Jasa Pembuatan Aplikasi, Website dan Internet Marketing | PT APPKEY
PT APPKEY adalah perusahaan IT yang khusus membuat aplikasi Android, iOS dan mengembangkan sistem website. Kami juga memiliki pengetahuan dan wawasan dalam menjalankan pemasaran online sehingga diharapkan dapat membantu menyelesaikan permasalahan Anda.

Jasa Pembuatan Aplikasi

Jasa Pembuatan Website

Jasa Pembuatan Paket Aplikasi

Jasa Pembuatan Internet Marketing

Tutorial

Subscribe Sekarang

Dapatkan beragam informasi menarik tentang bahasa pemrograman langsung melalui email Anda. Subscribe sekarang dan terus belajar bersama kami!

Blog Post Ranking 10

Tutorial PHP 22 : Cara Membuat Redirect PHP dengan Cepat dan Mudah

Jika Anda melakukan browsing di browser kesayangan Anda, mungkin Anda pernah melihat link yang berisikan “php redirect” atau yang...

Tutorial PHP 23 : Cara Membuat Messages Alert PHP

Alert box atau alert messages digunakan di situs web untuk menampilkan pesan peringatan kepada pengguna bahwa mereka telah memasukkan...

Tutorial PHP 2 : Cara Install PHP, Langkah Awal Belajar PHP

PHP adalah bahasa pemrograman gratis dan open source. Secara teknis tidak perlu menginstal PHP: sebagian besar host web dan...

Tutorial Python 9 : Cara Membuat Looping Python

Pada artikel sebelumnya, Codekey telah menjelaskan tentang Operasi Kondisional Python yang di dalamnya menyinggung tentang percabangan dan perulangan. Belajar...

Tutorial HTML/CSS 23 : Cara Membuat Form Sederhana dengan HTML

Form memiliki peran yang sangat krusial bagi website atau aplikasi untuk menjaga sistem keamanannya. Form HTML digunakan untuk mengumpulkan...

Tutorial SQL 8 : Constraint SQL, Bagaimana Fungsi dan Penggunaannya?

Pada artikel sebelumnya Anda telah mempelajari tentang wildcard SQL, pada artikel kali ini kami akan menjelaskan tentang constraint SQL. Jika...

Tutorial Javascript 8 : Array Javascript, Panduan Lengkap Cara Membuatnya

Seperti bahasa pemrograman yang berorientasi objek lainnya, dalam JavaScript juga terdapat array. Jika Anda memiliki banyak objek yang ingin...

Tutorial SQL 20 : Mari Pelajari Cara Menggunakan Fungsi GROUP by SQL

Pada pembahasan seri Tutorial SQL ke- 20 ini, Codekey akan membahas tentang GROUP BY yang merupakan statement di dalam...

Tutorial Python 7 : Python String Format dan Cara Mudahnya

Anda ingin belajar Python dan ingin menjadi ahli dalam bahasa pemrograman Python? Mari belajar bersama Codekey! Pada pembahasan kali...

Tutorial Python 8 : Langkah Mudah Membuat Operasi Kondisional pada Python

Pada pembahasan sebelumnya, Codekey telah menjelaskan kepada Anda tentang pengoperasian string pada Python mulai dari menggabungkan hingga memanipulasi string...

Bisnis

Online Service

Peluang Bisnis

Model Bisnis

Entrepreneurship

Uang

Ketrampilan

Outsourcing

Monetize

Pemasaran

SEO

Internet Marketing

Dasar Pemasaran

Strategi Pemasaran

Situs Web Analitik

Iklan

Teknologi

Teknologi Terbaru

AI

Komputer

Jaringan

Paling Sering dibaca
Mungkin Anda Menyukainya