SQL Server Foreign Key Constraint Kullanımı

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.

1.878 Kez Okundu

Yavuz Selim Kart

Yazılım ve veri tabanında bildiklerimi anlatmaya gayret ediyorum. Halen birçok programlama dili üzerinde araştırmalar yaparak kendimi geliştiriyorum. Bunlar haricinde Grafik Tasarım ve Wordpress konularına da ilgim bulunmakta. SEO ve Sosyal medya yönetimleri hakkında da bilgim mevcuttur. Kısaca çok çalışmayı seven azimli biriyim.

You may also like...

Yazı kopyalamak yasaktır!