Peranan pencetus SQL dan contoh kod khusus
Ikhtisar: Pencetus SQL ialah prosedur tersimpan khas, iaitu sekeping kod yang dilaksanakan secara automatik apabila data dalam pangkalan data berubah. Pencetus boleh mencetuskan pelaksanaan apabila data dimasukkan (INSERT), dikemas kini (KEMASKINI) atau dipadamkan (DELETE). Ia boleh digunakan untuk melaksanakan pelbagai kekangan data yang kompleks, logik perniagaan dan kawalan ketekalan data.
Fungsi:
- Kawalan integriti data: Melalui pencetus, kami boleh menentukan beberapa peraturan dalam pangkalan data untuk memastikan integriti dan konsistensi data. Sebagai contoh, anda boleh menggunakan pencetus untuk mengehadkan julat nilai medan, menyemak kekangan kunci asing bagi jadual berkaitan, dsb.
- Kawalan logik perniagaan: Pencetus boleh membantu kami melaksanakan kawalan logik perniagaan di peringkat pangkalan data. Contohnya, apabila rekod dimasukkan ke dalam jadual pesanan, jumlah pesanan boleh dikira secara automatik melalui pencetus dan dikemas kini ke medan yang sepadan.
- Penyegerakan dan replikasi data: Apabila melaksanakan penyegerakan dan replikasi data antara berbilang pangkalan data, pencetus boleh digunakan untuk menyegerakkan kemas kini kepada pangkalan data sasaran apabila perubahan data berlaku dalam pangkalan data sumber.
- Pengelogan dan pengauditan: Melalui pencetus, kami boleh melaksanakan fungsi pengelogan dan pengauditan untuk operasi pangkalan data. Iaitu, apabila data berubah, pencetus boleh merekodkan operasi yang berkaitan secara automatik untuk memudahkan pertanyaan dan penjejakan seterusnya.
Contoh Kod:
Berikut ialah contoh mudah yang menunjukkan cara mencipta pencetus dalam MySQL yang mengemas kini data jadual ringkasan lain secara automatik apabila rekod baharu dimasukkan.
- Buat dua jadual:
CREATE TABLE orders (
id INT PRIMARY KEY,
amount DECIMAL(8,2),
status ENUM('pending', 'complete')
);
CREATE TABLE summary (
total_amount DECIMAL(8,2)
);
- Buat pencetus untuk mengemas kini medan jumlah_jumlah secara automatik dalam jadual ringkasan apabila rekod baharu dimasukkan dalam jadual pesanan:
DELIMITER $$
CREATE TRIGGER update_summary AFTER INSERT ON orders
FOR EACH ROW
BEGIN
UPDATE summary SET total_amount = total_amount + NEW.amount;
END$$
DELIMITER ;
mencetuskan rekod baru untuk mencetuskan : INSERT INTO orders (id, amount, status) VALUES (1, 100.00, 'complete');
Soal jadual ringkasan dan sahkan kesan pencetus: SELECT * FROM summary;
Melalui contoh kod di atas, kita dapat melihat bahawa apabila rekod baharu dimasukkan ke dalam jadual pesanan, pencetus akan mengemas kini ringkasan secara automatik table. , dengan itu mengemas kini medan jumlah_jumlah dalam masa nyata.
Ringkasan:
SQL trigger ialah alat berkuasa yang boleh melaksanakan sekeping kod secara automatik apabila data berubah. Melalui pencetus, kami boleh melaksanakan fungsi seperti kawalan integriti data, kawalan logik perniagaan, penyegerakan dan replikasi data, pengelogan dan pengauditan. Dalam pembangunan aplikasi sebenar, penggunaan rasional pencetus boleh meningkatkan keselamatan dan kebolehpercayaan pangkalan data.
Atas ialah kandungan terperinci Aplikasi pencetus SQL. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!
Kenyataan:Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn