SQL Server Foreign Key Constraint Kullanımı
Herkese merhaba,
Bu yazıda sizlere SQL Server’da Foreign Key Constraint kullanımından bahsedeceğim.
SQL Server’da Foreign Key Constraintler bir tablodaki sütun değerinin, ilişkili olduğu başka bir tablodaki sütun değerinden geldiğini doğrulamak için kullanılan bir kısıtlamadır. Konu hakkındaki örneği aşağıda görebilirsiniz.
CREATE TABLE Musteriler ( MusteriID INT NOT NULL , Ad VARCHAR(20) NOT NULL , Yas INT NOT NULL , Adresi CHAR(25) , Maasi DECIMAL(18, 2) , PRIMARY KEY ( MusteriID ), ); CREATE TABLE Siparisler ( SiparisID INT PRIMARY KEY NOT NULL , Tarih DATETIME, MusteriID INT CONSTRAINT FK_SiparislerMusterileri FOREIGN KEY (MusteriID) REFERENCES Musteriler(MusteriID), Miktar INT );
Burada Musteriler diye bir tablomuz mevcut. Müşterilerimizin siparişilerinin tutulacağı Siparisler diye bir tablo daha oluşturuyoruz. Siparişler tablomuzu oluştururken Foreign Key alanı olarak MusteriID kısmını referans alıyoruz. Yani Siparisler kısmındaki MusteriID alanını Musteriler tablosundaki MusteriID alanına referans ediyoruz. En başta da Constrait diyoruz ve sonrasında bu Constraint’in adını belirtiyoruz. İşlemi şöyle düşünebiliriz. Tablolarımıza veri eklerken ilk olarak Musteriler tablosuna veri eklememiz gerekli. Neden ilk buraya veri eklememiz gerekli? Çünkü müşterimiz olmadan herhangi bir siparişimizin olması mümkün değil. Zaten veri ekleme yapınca da sizden Musteriler tablosunda tutulan bir MusteriID değeri isteyecektir. Eğer Musteriler tablosunda olmayan rastgele bir değer girerseniz yine bir uyarı alacaksınız. İlişkiyi SQL Server’da diyagram olarak aşağıdaki şekilde görebilirsiniz.
Görüldüğü üzere ana tablomuz Musteriler tablosudur.
İki tablo arasındaki Foreign Key alanını kaldırmak için ise aşağıdaki kodu yazıyoruz.
ALTER TABLE Siparisler DROP CONSTRAINT FK_SiparislerMusteriler;
Diyagramda sonucu aşağıdaki gibi görebiliriz.
Görüldüğü üzere aralarında herhangi bir ilişki kalmamıştır.
Siparişler tablosuna Foreign Key tanımlaması yapmak için aşağıdaki kodu yazmalıyız.
ALTER TABLE Siparisler ADD FOREIGN KEY (MusteriID) REFERENCES dbo.Musteriler(MusteriID)
Burada Siparisler tablosundaki MusteriID ile Musteriler tablosundaki MusteriID alanını kullanarak bir foreign key tanımlaması yaptık. Dikkat edilmesi gereken nokta ise işlemi daha önce oluşturulmuş iki tablo üzerinde yaptığımız. Bundan dolayı ALTER TABLE ifadesini kullandık.
Herkese çalışma hayatında ve yaşamında başarılar kolaylıklar.