24 Eylül 2020 Perşembe

Trigger Nedir?

Merhabalar, bu makalemde trigger nedir, bir trigger nasıl yazılır bu konular hakkında bilgiler edineceksiniz.

Trigger kelime anlamı tetikleyicidir. RDBMS yani ilişkisel veri tabanı yönetim sistemlerinde aktif olarak kullanılır. Veri tabanı nesnesi olup bir tabloda belirli olayların meydana gelmesi durumunda veya olayların öncesinde çalışacak bir stored procedure çeşididir. 

Tabloda meydana gelebilecek olaylar veri ekleme, veri güncelleme veya veri silme işlemleridir. Bu işlemlerden sonra bir iş yaptırmak istersek (aynı tablo ya da farklı bir tabloda) trigger yapısından yararlanırız.

Örneğin;

  • Satış tablosundaki bir ürünün satılması sonrasında o ürünün stok miktarının eksiltilmesi 
  • Banka hesabında para transferi sonrasında otomatik email gönderilmesi 
  • Kayıt silinmek istendiğinde bu kaydın silinemeyeceğinin bilgilendirilmesi 
  • Öğrenci tablosundaki kaydın silinmesi durumunda silinen bu kaydı başka bir aktarılması
Yukarıdaki maddeleri gerçekleştirmek istediğimizde trigger kullanabiliriz. 

Neden Trigger Kullanmalıyız?

Verilerin bütünlüğünü sağlamak için kullanmayı tercih ederiz ya da tablolarda, veri tabanında mevcut olmayan fakat ihtiyacımız olan bilgileri hesaplamak istediğimizde kullanırız.
Örneğin sipariş tablosunda miktar sütununda bir güncelleme meydana geldiğinde toplam_fiyat sütununa karşılık gelen işlemi hesaplayabiliriz.

Trigger Çeşitleri

  1. DML(Data Manipulation Language) Trigger
  2. DDL(Data Definition Language) Trigger
  3. Logon Trigger


1.DML Trigger 

Veri tabanına yapılan veri işleme komutlarını yani insert,update ve delete işlemlerini içeren trigger çeşididir. DML Trigger kullanarak yapacağımız işi "primary key","foreign key", "unique" constraint yapılarını kullanarak da yapabiliriz. Constraint yapılarının yetersiz kaldığı durumlarda DML Trigger yapılarını kullanmayı tercih ederiz. 


DML trigger’ları hazırlarken "inserted ve deleted" isimli tabloları kullanırız.
Örneğin,

  • Bir insert işlemi gerçekleştiğinde "inserted tablosunda" insert edilen kayıtları,
  • Bir update ya da delete işlemi gerçekleştiğinde ise "deleted tablosunda" silinen kayıtları görebiliriz.
1.a After - For
1.a.a After insert
1.a.b After update
1.a.b After delete

1.b Instead of
1.b.a Instead of insert
1.b.b Instead of update
1.b.c Instead of delete

2.DDL Trigger

CREATE DATABASE, DROP DATABASE
Create Table, Alter Table, Drop Table
Create Function,Alter Function,Drop Function
Create View,Alter View,Drop View
Create Stored Procedure,Alter Stored Procedure, Drop Stored Procedure

Veri tabanına yapılan yukarıdaki değişiklik işlemleri gerçekleştiğinde tetiklenebilir. Hangi işlemden sonra tetikleneceğinin bilgisini Trigger’ı tanımlarken belirtiriz.


3.Logon Trigger

Kullanıcı login olmak için giriş yaptığında login ve şifre bilgileri kontrol edildikten sonra eğer bağlantı bilgileri doğruysa bağlantı gerçekleşmeden tetiklenir.

Hangi trigger çeşidini kullanmamız gerektiğine işimizin akışına göre karar vermemiz gerekecektir.



Hiç yorum yok:

Yorum Gönder

SQL Çalışma Sorularının Çözümü

 -Ürünler tablosundaki ürünlerden Rengi siyah,silver ya da multi renkte olanları fiyat bilgisine göre büyükten küçüğe getirilip gösterilecek...