Jawaban bagus dari Rolando.
Selain itu - Pemicu tidak boleh digunakan untuk logika, karena beberapa pemicu yang saling terkait nanti, semuanya akan membingungkan dengan cepat. Seperangkat instruksi yang bagus dalam prosedur tersimpan atau prosedur sisi klien dapat melintasi logika bisnis lebih jelas daripada sekelompok logika tersembunyi dalam database. Ada juga batasan pada pemicu sehubungan dengan tabel mereka dipicu dari - jadi Anda mungkin menemukan diri Anda membelah logika Anda di dua tempat yang berbeda ..
Selain itu - Anda mungkin menemukan cara untuk mengoptimalkan pada titik apa perhitungan ini terjadi di server logika bisnis Anda, sedangkan pemicu akan dipicu setiap saat. Anda akan menemukan diri Anda mematikan pelatuk, memperbarui meja, dan kemudian kembali memungkinkan memicu - yang juga berarti Anda harus menempatkan logika memicu dalam yang kode.
Selain itu - Anda tidak harus memiliki semua logika di bagian logika bisnis dari kode - Anda mungkin ingin menegakkan integritas tabel dengan menggunakan prosedur tersimpan. Ini dapat memulai transaksi, melakukan banyak pembaruan, dan membuat semuanya kembali dengan baik jika ada yang gagal. Dengan cara itu seseorang yang melihat database dapat melihat logika untuk memasukkan pesanan, misalnya. Ini kurang penting di dunia saat ini karena layanan web dapat menjadi antarmuka akses tunggal ke db; tetapi dalam kasus di mana banyak executable memiliki akses ke DB ini bisa sangat besar.
Selain itu - Anda akan tetap melakukan transaksi - Anda tidak akan menjalankan pemicu Anda tanpa ... benar? Jadi, baik untuk mengetahui cara memulai transaksi; melakukan beberapa hal; dan kemudian mengakhiri transaksi. Jika Anda melihat pola ini dalam kode Anda, satu lagi kode yang menggunakannya akan menjadi ringan pada beban kognitif. Pemicu, jika Anda ingat bahwa itu ada, akan memaksa Anda untuk berpikir secara berbeda untuk transaksi-transaksi yang dipengaruhi oleh pemicu, terutama jika tabel lain ditarik yang juga mungkin memiliki pemicu.
Pada dasarnya, antara pekerjaan cron yang dijadwalkan secara rutin (atau pekerjaan agen basis data) dan prosedur tersimpan yang baik, Anda dapat mencapai 99% dari apa yang Anda inginkan. 1%; memikirkan kembali proyek.