Eyl 13   MySQL ve Triggerlar

Tags Kategori? Veritabanı  | Yorumlar » 20 yorum

AraçlarNe kadar uzun zamandır yazmadığımı farkedince, kendime çeki düzen verip işe yarayacak bir tutorial yazayım dedim. Hem de birçok kişinin bir zamanlar MySQL’i ezik bulma nedeniyle ilgili. MySQL 5.0 alpha‘ya kadar trigger desteği bulunmayan bir veritabanı yönetim sistemi olduğundan çoğu kez bu nedenle çocukça bir uğraş olarak görülmüştür - abartmıyorum. Yeni sürümlerine entegre edilen trigger desteği sayesinde MySQL severler oldukça büyük bir huzura kavuşmuştur.

Bunları boşverip, işe başlayalım:

TRIGGER NEDİR? İlk cevaplamamız gereken soru bu. Trigger’lar ilişkisel veri tabanlarıda belirli bir olay/durum ortaya çıktığında belirli bir işin yapılmasını sağlayan özelliklerdir. Bu işler daha önce yaratılmalı ve veritabanında saklanmalıdır.

Peki, bu prosedür ve işlemleri nerede kullanabiliriz? Hemen, örnek bir olay yaratalım. Mesela bir blogumuz olsun ve bu blogda yazıları ve yorumları tutan iki tane tablo olsun. Yazılar tablosunun aşağıdaki yapıda olduğunu farzedelim:

Posts Tablosu

Yazılar dışında bir de yorumları sakladığımız bir “comments” tablosu var demiştim. Bu tablonun yapısı ise basitçe aşağıdaki gibi olsun.

Comments tablosu

Comments üzerindeki parent_id, posts tablosundaki id’yi referans ediyor ve yorumun hangi yazı için yazıldığını belirliyor. Blogumuza her yeni yorum eklendikten sonra posts tablosundaki “count”un artması isteriz, her yorum silindiğinde ise azaltılmasını. Böyle bir durumda programlamaya başvurarak bu işi halledebiliriz, ama program dışında birileri direkten database üzerinden bir yorum silmek isterse, ayrıca manuel olarak “count” değerini de değiştirmesi gerekecektir. Bu işkenceye son vermek amacıyla trigger’lar yaratılabilinir. Aşağıda her yorum eklendiğinde ona ait yazının count’unu bir arttıran bir trigger nasıl yaratılır bunu inceleyeceğiz. DEVAMINI DA OKU »»»