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

क्या PostgreSQL फंक्शन ट्रांजेक्शनल हैं?

PostgreSQL 12 अपडेट :शीर्ष-स्तरीय PROCEDURE . के लिए सीमित समर्थन है s जो लेनदेन नियंत्रण कर सकता है। आप अभी भी नियमित SQL-कॉल करने योग्य फ़ंक्शन में लेन-देन का प्रबंधन नहीं कर सकते हैं, इसलिए नई शीर्ष-स्तरीय प्रक्रियाओं का उपयोग करने के अलावा नीचे दी गई जानकारी सही रहती है।

फ़ंक्शंस उस लेन-देन का हिस्सा हैं जिनसे उन्हें बुलाया जाता है। यदि लेन-देन वापस ले लिया जाता है तो उनके प्रभाव वापस लुढ़क जाते हैं। यदि लेन-देन करता है तो उनका काम होता है। कोई भी BEGIN ... EXCEPT फ़ंक्शन के भीतर ब्लॉक SAVEPOINT जैसे सेवपॉइंट की तरह (और हुड के उपयोग के तहत) काम करते हैं और ROLLBACK TO SAVEPOINT SQL कथन।

BEGIN ... EXCEPT को छोड़कर, फ़ंक्शन या तो पूरी तरह से सफल हो जाता है या पूरी तरह से विफल हो जाता है त्रुटि प्रबंधन। यदि फ़ंक्शन के भीतर कोई त्रुटि उठाई जाती है और उसे संभाला नहीं जाता है, तो फ़ंक्शन को कॉल करने वाला लेनदेन निरस्त कर दिया जाता है। निरस्त किए गए लेनदेन प्रतिबद्ध नहीं हो सकते हैं, और यदि वे COMMIT करने का प्रयास करते हैं ROLLBACK . के रूप में माना जाता है , जैसा कि किसी अन्य त्रुटिपूर्ण लेनदेन के लिए है। ध्यान दें:

regress=# BEGIN;
BEGIN
regress=# SELECT 1/0;
ERROR:  division by zero
regress=# COMMIT;
ROLLBACK

देखें कि लेन-देन, जो शून्य विभाजन के कारण त्रुटि स्थिति में है, COMMIT पर वापस कैसे आता है ?

यदि आप एक स्पष्ट आसपास के लेन-देन के बिना किसी फ़ंक्शन को कॉल करते हैं तो नियम बिल्कुल वैसे ही होते हैं जैसे किसी अन्य पीजी स्टेटमेंट के लिए:

BEGIN;
SELECT refresh_materialized_view(name);
COMMIT;

(जहां COMMIT विफल हो जाएगा यदि SELECT एक त्रुटि उठाई)।

PostgreSQL (अभी तक) कार्यों में स्वायत्त लेनदेन का समर्थन नहीं करता है, जहां प्रक्रिया/कार्य कॉलिंग लेनदेन से स्वतंत्र रूप से प्रतिबद्ध/रोलबैक कर सकता है। इसे dblink के माध्यम से एक नए सत्र का उपयोग करके अनुकरण किया जा सकता है।

लेकिन , ऐसी चीजें जो लेन-देन संबंधी नहीं हैं या अपूर्ण रूप से लेन-देन वाली हैं, PostgreSQL में मौजूद हैं। यदि इसका सामान्य BEGIN; do stuff; COMMIT; ब्लॉक, इसका एक फ़ंक्शन में गैर-लेनदेन व्यवहार भी है। उदाहरण के लिए, nextval और setval , TRUNCATE , आदि.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. PostgreSQL क्वेरी कैसे लॉग करें?

  2. PostgreSQL डेटाबेस को SQLServer एक में कैसे माइग्रेट करें?

  3. Ansible PostgreSQL को प्यार करता है

  4. pg_ctl युक्तियाँ और तरकीबें

  5. PgBouncer में नया क्या है 1.6