PostgreSQL
 sql >> डेटाबेस >  >> RDS >> PostgreSQL

पोस्टग्रेज ट्रिगर डालने के बाद NEW

बढ़िया मैनुअल से:

<ब्लॉकक्वॉट>

36.1. ट्रिगर व्यवहार का अवलोकन
[...]
पंक्ति-स्तरीय ट्रिगर के लिए, इनपुट डेटा में NEW भी शामिल होता है INSERT . के लिए पंक्ति और UPDATE ट्रिगर, और/या OLD UPDATE के लिए पंक्ति और DELETE ट्रिगर स्टेटमेंट-लेवल ट्रिगर्स के पास वर्तमान में स्टेटमेंट द्वारा संशोधित अलग-अलग पंक्तियों की जांच करने का कोई तरीका नहीं है।

और ट्रिगर प्रक्रियाओं से:

<ब्लॉकक्वॉट>

NEW
डेटा प्रकार RECORD; INSERT . के लिए नई डेटाबेस पंक्ति धारण करने वाला चर /UPDATE पंक्ति-स्तर ट्रिगर में संचालन। यह वेरिएबल NULL है स्टेटमेंट-लेवल ट्रिगर्स में और DELETE . के लिए संचालन।

ध्यान दें कि यह पंक्ति-स्तरीय ट्रिगर और कथन-स्तरीय ट्रिगर के बारे में क्या कहता है।

आपके पास एक कथन-स्तरीय ट्रिगर है:

...
FOR EACH STATEMENT
EXECUTE PROCEDURE f_log_datei();

स्टेटमेंट-लेवल ट्रिगर्स प्रति स्टेटमेंट एक बार ट्रिगर होते हैं और एक स्टेटमेंट कई पंक्तियों पर लागू हो सकता है, इसलिए प्रभावित पंक्ति की धारणा (जो है NEW और OLD के बारे में हैं) बस लागू नहीं होता।

यदि आप NEW का उपयोग करना चाहते हैं (या OLD ) एक ट्रिगर में तो आप चाहते हैं कि ट्रिगर प्रत्येक प्रभावित पंक्ति के लिए निष्पादित हो और इसका मतलब है कि आप एक पंक्ति-स्तरीय ट्रिगर चाहते हैं:

CREATE TRIGGER log_datei AFTER INSERT OR UPDATE OR DELETE
ON dateien
FOR EACH ROW
EXECUTE PROCEDURE f_log_datei();

मैंने अभी-अभी FOR EACH STATEMENT को बदला है करने के लिए FOR EACH ROW

आपका ट्रिगर भी कुछ लौटा रहा होगा:

<ब्लॉकक्वॉट>

एक ट्रिगर फ़ंक्शन को या तो NULL लौटाना चाहिए या एक रिकॉर्ड/पंक्ति मान जिसमें ठीक उसी तालिका की संरचना हो जिसके लिए ट्रिगर को सक्रिय किया गया था।
[...]
एक पंक्ति-स्तरीय ट्रिगर का वापसी मान सक्रिय किया गया AFTER या कथन-स्तरीय ट्रिगर BEFORE सक्रिय किया गया है या AFTER हमेशा अनदेखा किया जाता है; यह शून्य भी हो सकता है। हालांकि, इनमें से कोई भी ट्रिगर अभी भी त्रुटि उत्पन्न करके पूरे ऑपरेशन को रोक सकता है।

तो आपको RETURN NEW; या RETURN NULL; आपके ट्रिगर में। आपके पास एक ट्रिगर के बाद है, इसलिए इससे कोई फर्क नहीं पड़ता कि आप किस रिटर्न का उपयोग करते हैं, लेकिन मैं RETURN NEW; के साथ जाऊंगा ।




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. निर्दिष्ट निर्देशांक से 5 मील की सीमा में सभी भवन प्राप्त करना

  2. साधारण Postgresql कथन - स्तंभ नाम मौजूद नहीं है

  3. PostgreSQL Upsert सिस्टम कॉलम XMIN, XMAX और अन्य का उपयोग करके सम्मिलित और अद्यतन पंक्तियों में अंतर करता है

  4. sqlalchemy का उपयोग करके postgresql से कनेक्ट करते समय त्रुटि

  5. PostgreSQL हिम्मत:"रेसजंक" क्या है?