डालने और अद्यतन दोनों के लिए MySQL फायर ट्रिगर


111

क्या किसी तालिका के सम्मिलित और अद्यतन घटनाओं के लिए mysql ट्रिगर को फायर करना संभव है?

मुझे पता है कि मैं निम्नलिखित कर सकता हूं

CREATE TRIGGER my_trigger
    AFTER INSERT ON `table`
    FOR EACH ROW
BEGIN
.....
END //

CREATE TRIGGER my_trigger
    AFTER UPDATE ON `table`
    FOR EACH ROW
BEGIN
.....
END //

लेकिन मैं कैसे कर सकता हूं

CREATE TRIGGER my_trigger
    AFTER INSERT ON `table` AND
    AFTER UPDATE ON `table`
    FOR EACH ROW
BEGIN
.....

क्या यह संभव है, या क्या मुझे 2 ट्रिगर्स का उपयोग करना है? कोड दोनों के लिए समान है और मैं इसे दोहराना नहीं चाहता।

जवाबों:


126

आपको दो ट्रिगर बनाने होंगे, लेकिन आप सामान्य कोड को एक प्रक्रिया में स्थानांतरित कर सकते हैं और उन दोनों को प्रक्रिया को कॉल कर सकते हैं।


3
क्या आप हम में से उन लोगों के लिए एक खिलौना उदाहरण दे सकते हैं जो वाक्य रचना से अपरिचित हैं?
Zxaos

3
@Zxaos: मेरा सुझाव है कि मैं dev.mysql.com/doc/refman/5.1/en/create-procedure.html (जिसमें कुछ उदाहरण शामिल हैं) और यदि आवश्यक हो तो अपना प्रश्न पूछें।
जुलूस

2
यह एक अफ़सोस की बात है कि हम Oracle की तरह AND / OR ऑपरेटरों का उपयोग नहीं कर सकते हैं, और भी अधिक जब हम एक प्रक्रिया के लिए पैरामीटर द्वारा पूरे चर OLD और NEW को पारित नहीं कर सकते। मेरा कोड होगा> 2x
मिकेल

एक डेवलपर के लिए यह एक उपयोगी है जो कभी भी दो बार कोड लिखने से समझौता नहीं करता है ..
Sayka

1
@luismartingil में किसी प्रक्रिया को कॉल करने का कुछ अतिरिक्त ओवरहेड होता है, इसे इनलाइन करके। लेकिन बदले में आपको आसान रखरखाव और एक गारंटी मिलती है कि दो ट्रिगर कोड गलती से नहीं हटेंगे।
derobert

46

@Zxaos अनुरोध के जवाब में, क्योंकि हमारे पास MySQL ट्रिगर्स के लिए AND / OR ऑपरेटर नहीं हो सकते हैं, जो आपके कोड से शुरू होता है, नीचे उसी को प्राप्त करने के लिए एक पूर्ण उदाहरण है।

1. INSERT ट्रिगर को परिभाषित करें:

DELIMITER //
DROP TRIGGER IF EXISTS my_insert_trigger//
CREATE DEFINER=root@localhost TRIGGER my_insert_trigger
    AFTER INSERT ON `table`
    FOR EACH ROW

BEGIN
    -- Call the common procedure ran if there is an INSERT or UPDATE on `table`
    -- NEW.id is an example parameter passed to the procedure but is not required
    -- if you do not need to pass anything to your procedure.
    CALL procedure_to_run_processes_due_to_changes_on_table(NEW.id);
END//
DELIMITER ;

2. अद्यतन ट्रिगर को परिभाषित करें

DELIMITER //
DROP TRIGGER IF EXISTS my_update_trigger//

CREATE DEFINER=root@localhost TRIGGER my_update_trigger
    AFTER UPDATE ON `table`
    FOR EACH ROW
BEGIN
    -- Call the common procedure ran if there is an INSERT or UPDATE on `table`
    CALL procedure_to_run_processes_due_to_changes_on_table(NEW.id);
END//
DELIMITER ;

3. इन दोनों ट्रिगर्स द्वारा उपयोग किए जाने वाले सामान्य प्रक्रिया को परिभाषित करें:

DELIMITER //
DROP PROCEDURE IF EXISTS procedure_to_run_processes_due_to_changes_on_table//

CREATE DEFINER=root@localhost PROCEDURE procedure_to_run_processes_due_to_changes_on_table(IN table_row_id VARCHAR(255))
READS SQL DATA
BEGIN

    -- Write your MySQL code to perform when a `table` row is inserted or updated here

END//
DELIMITER ;

आप ध्यान दें कि जब मैं अपने व्यवसाय को ट्रिगर और प्रक्रिया को परिभाषित करने के साथ किया जाता हूं, तो मैं सीमांकक को पुनर्स्थापित करने का ध्यान रखता हूं।


1
IN table_row_id VARCHAR(255)इस मामले में क्या है ? मेरा मतलब है कि आप कैसे परिभाषित कर रहे हैं कि किस पंक्ति को डाला या अपडेट किया जा रहा है?
वोटो

13

दुर्भाग्य से हम Oracle की तरह, INSERT या अद्यतन विवरण के बाद MySQL में उपयोग नहीं कर सकते

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.