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

डिलीट करने से पहले ट्रिगर चेक राशि पोस्टग्रेज करें

आप इसे AFTER DELETE स्टेटमेंट-लेवल ट्रिगर के साथ हासिल कर सकते हैं। ट्रिगर फ़ंक्शन के अंदर आप प्रभावित पंक्तियों की संख्या गिन सकते हैं और यदि गिनती बहुत अधिक है तो एक अपवाद फेंक सकते हैं। अपवाद उस लेन-देन को वापस लेने के लिए बाध्य करेगा जिसने हटाना शुरू किया था।

create function prevent_delete()
  returns trigger
as
$BODY$ 
declare
  l_count integer;
begin 
  select count(*)
    into l_count
  from old_table;

  if l_count > 5 then 
    raise exception 'Too many rows would be deleted';
  end if; 
  return null;
end; 
$BODY$ 
LANGUAGE plpgsql;

और फिर ट्रिगर बनाएं:

create trigger prevent_mass_delete 
   after delete on the_table
   referencing old table as old_table
   for each statement 
   execute procedure prevent_delete();



  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 में आरक्षण से केवल कार्य समय कैसे वापस करें?

  3. डेटा पीढ़ी और हार्डवेयर गुणवत्ता

  4. त्रुटि:ऑपरेटर मौजूद नहीं है:संख्यात्मक ~* अज्ञात

  5. PostgreSQL 9.5 - JSON के साथ NULL को मर्ज करते समय अपडेट काम नहीं करता है