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

Oracle DBMS में रिकॉर्ड हटाने के लिए संग्रहीत प्रक्रिया

यहां डेटाबेस_डिक्शनरी का उपयोग करके सभी चाइल्ड टेबल के लिए एक पैरेंट टेबल से डेटा को हटाने के लिए एक नमूना कोड है, मुझे इसे लिखने में बहुत मज़ा आया;-) उस व्यक्ति से अंतिम पंक्ति हटाएं जहां pk ='38B567E2909447868ABDDF500B78F2A3'; आसानी से सामान्यीकृत किया जा सकता है। जोड़ने के लिए एक और बात, यह स्क्रिप्ट काम नहीं करती है यदि आपके पास दो कॉलम या अधिक की प्राथमिक बाधाएं हैं...

declare 
  TYPE cur_typ IS REF CURSOR;
  procedure delete_from_sub_table_first(p_current_table_name varchar2, l_parent_key_value varchar2) is
     c cur_typ;
     child_table_pm_key_value varchar2(255);
  begin
    for childConsRecord in (select ac.table_name child_table, acc.column_name Child_column, rac.table_name, racc.COLUMN_NAME, (select column_name from ALL_CONS_COLUMNS accpm, all_constraints acpm where accpm.constraint_name = acpm.constraint_name and acpm.CONSTRAINT_TYPE = 'P' and ac.TABLE_NAME = acpm.TABLE_NAME) child_table_pm_key
                  from ALL_CONS_COLUMNS acc, all_constraints ac, ALL_CONS_COLUMNS racc, all_constraints rac
                  where acc.CONSTRAINT_NAME = ac.CONSTRAINT_NAME
                  and ac.CONSTRAINT_TYPE = 'R'
                  and racc.CONSTRAINT_NAME  = rac.CONSTRAINT_NAME
                  and rac.constraint_name = ac.R_CONSTRAINT_NAME
                  and rac.table_name = p_current_table_name) loop
      OPEN c FOR 'select ' || childConsRecord.child_table_pm_key || ' child_value FROM ' || childConsRecord.child_table || ' where ' || childConsRecord.Child_column || ' = :1' using l_parent_key_value;
      LOOP
          FETCH c INTO child_table_pm_key_value;
          EXIT WHEN c%NOTFOUND;
          -- process row here
          delete_from_sub_table_first(childConsRecord.child_table, child_table_pm_key_value);
      END LOOP;
      close c;
      EXECUTE IMMEDIATE 'DELETE FROM ' || childConsRecord.child_table || ' where ' || childConsRecord.Child_column || ' = :1' using l_parent_key_value;        
    end loop;
  end;
begin  
  delete_from_sub_table_first('PERSON', '38B567E2909447868ABDDF500B78F2A3');
  delete from person where pk = '38B567E2909447868ABDDF500B78F2A3';
end;
/



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. CASE कथनों के परिणाम जोड़ना

  2. Oracle से डुप्लिकेट पंक्तियां हटाएं

  3. Oracle:दो तालिकाओं को विभिन्न स्तंभों के साथ संयोजित करें

  4. Oracle sql में एक तालिका के रूप में सीमांकित स्ट्रिंग का चयन करना

  5. iReport पैरामीटर के माध्यम से क्वेरी करने के लिए SQL ऑपरेटरों को पास करना