PSD-Tutorials.de
Forum für Design, Fotografie & Bildbearbeitung
Tutkit
Agentur
Hilfe
Kontakt
Start
Forum
Aktuelles
Besonderer Inhalt
Foren durchsuchen
Tutorials
News
Anmelden
Kostenlos registrieren
Aktuelles
Suche
Suche
Nur Titel durchsuchen
Von:
Menü
Anmelden
Kostenlos registrieren
App installieren
Installieren
JavaScript ist deaktiviert. Für eine bessere Darstellung aktiviere bitte JavaScript in deinem Browser, bevor du fortfährst.
Du verwendest einen veralteten Browser. Es ist möglich, dass diese oder andere Websites nicht korrekt angezeigt werden.
Du solltest ein Upgrade durchführen oder einen
alternativen Browser
verwenden.
Antworten auf deine Fragen:
Neues Thema erstellen
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
SQL-Frage
Beitrag
<blockquote data-quote="Chaya93" data-source="post: 1761544" data-attributes="member: 440722"><p>hallo zusammen!</p><p></p><p>Ich habe folgendes Problem.</p><p></p><p>Und zwar habe ich zwei Tabellen, von der eine auf die andere über einen FK referenziert.</p><p></p><p>Tabelle_A</p><p>- A_Id (PK)</p><p>- ...</p><p>- ...</p><p>- ...</p><p></p><p>Tabelle_B</p><p>- B_Id (PK)</p><p>- A_Id (FK)</p><p>- ...</p><p>- ...</p><p></p><p></p><p>Die beiden Tabellen sind wiederum in Partitionen unterteilt.</p><p>Mein Ziel ist es nun eine Partition in Tabelle_A vollständig zu löschen, wenn das eingegebene Datum älter ist, als das Enddatum einer Partition (dies soll mittels truncate gelöst werden).</p><p>Nun sollen aber auch die Daten in Tabelle_B gelöscht werden, wenn sie als FK die Id eines gelöschten Datensatzes aus Tabelle_A haben.</p><p>Mit Delete funktioniert das Ganze.</p><p></p><p>folgenden Code habe ich schon:</p><p></p><p>[CODE]<<deletePartitionDataLoop>> FOR i IN v_p_to_archive.first .. v_p_to_archive.last --hier werden alle partitionsINHALTE gelöscht</p><p> LOOP </p><p> select to_char(sysdate, 'YYYY-MM-DD HH24:Mi:SS') into v_curtime from dual;</p><p> dbms_output.put_line(v_curtime || ' - Truncating partiton ' || v_p_to_archive(i));</p><p> BEGIN</p><p> v_sql1 := 'ALTER TABLE TABELLE_A TRUNCATE PARTITION (' || v_p_to_archive(i) || ')';</p><p> EXECUTE IMMEDIATE v_sql1;</p><p> EXCEPTION</p><p> WHEN OTHERS THEN</p><p> select to_char(sysdate, 'YYYY-MM-DD HH24:Mi:SS') into v_curtime from dual;</p><p> dbms_output.put_line(v_curtime || 'ERROR while truncating partition ' || v_p_to_archive(i) || ' with statement: ' || v_sql1 ||' - ' || SQLERRM);</p><p> ROLLBACK;</p><p> RAISE;</p><p> END;</p><p> END LOOP; </p><p> </p><p></p><p> </p><p> <<deletePartitionLoop>> FOR i In v_p_to_archive.first .. v_p_to_archive.last --partitionen selber werden gelöscht </p><p> LOOP</p><p> select to_char(sysdate, 'YYYY-MM-DD HH24:Mi:SS') into v_curtime from dual;</p><p> dbms_output.put_line(v_curtime || ' - Deleting partiton ' || v_p_to_archive(i));</p><p> BEGIN</p><p> v_sql2 := 'ALTER TABLE TABELLE_A DROP PARTITION ' || v_p_to_archive(i);</p><p> EXECUTE IMMEDIATE v_sql2;</p><p> EXCEPTION</p><p> WHEN OTHERS THEN</p><p> select to_char(sysdate, 'YYYY-MM-DD HH24:Mi:SS') into v_curtime from dual;</p><p> dbms_output.put_line(v_curtime || 'ERROR while dropping partition ' || v_p_to_archive(i) || ' with statement: ' || v_sql2 ||' - ' || SQLERRM);</p><p> ROLLBACK;</p><p> RAISE;</p><p> END;</p><p> END LOOP;[/CODE]Ich hoffe ihr könnt mir hier helfen!</p><p></p><p>Danke und Grüße,</p><p>Chaya</p></blockquote><p></p>
[QUOTE="Chaya93, post: 1761544, member: 440722"] hallo zusammen! Ich habe folgendes Problem. Und zwar habe ich zwei Tabellen, von der eine auf die andere über einen FK referenziert. Tabelle_A - A_Id (PK) - ... - ... - ... Tabelle_B - B_Id (PK) - A_Id (FK) - ... - ... Die beiden Tabellen sind wiederum in Partitionen unterteilt. Mein Ziel ist es nun eine Partition in Tabelle_A vollständig zu löschen, wenn das eingegebene Datum älter ist, als das Enddatum einer Partition (dies soll mittels truncate gelöst werden). Nun sollen aber auch die Daten in Tabelle_B gelöscht werden, wenn sie als FK die Id eines gelöschten Datensatzes aus Tabelle_A haben. Mit Delete funktioniert das Ganze. folgenden Code habe ich schon: [CODE]<<deletePartitionDataLoop>> FOR i IN v_p_to_archive.first .. v_p_to_archive.last --hier werden alle partitionsINHALTE gelöscht LOOP select to_char(sysdate, 'YYYY-MM-DD HH24:Mi:SS') into v_curtime from dual; dbms_output.put_line(v_curtime || ' - Truncating partiton ' || v_p_to_archive(i)); BEGIN v_sql1 := 'ALTER TABLE TABELLE_A TRUNCATE PARTITION (' || v_p_to_archive(i) || ')'; EXECUTE IMMEDIATE v_sql1; EXCEPTION WHEN OTHERS THEN select to_char(sysdate, 'YYYY-MM-DD HH24:Mi:SS') into v_curtime from dual; dbms_output.put_line(v_curtime || 'ERROR while truncating partition ' || v_p_to_archive(i) || ' with statement: ' || v_sql1 ||' - ' || SQLERRM); ROLLBACK; RAISE; END; END LOOP; <<deletePartitionLoop>> FOR i In v_p_to_archive.first .. v_p_to_archive.last --partitionen selber werden gelöscht LOOP select to_char(sysdate, 'YYYY-MM-DD HH24:Mi:SS') into v_curtime from dual; dbms_output.put_line(v_curtime || ' - Deleting partiton ' || v_p_to_archive(i)); BEGIN v_sql2 := 'ALTER TABLE TABELLE_A DROP PARTITION ' || v_p_to_archive(i); EXECUTE IMMEDIATE v_sql2; EXCEPTION WHEN OTHERS THEN select to_char(sysdate, 'YYYY-MM-DD HH24:Mi:SS') into v_curtime from dual; dbms_output.put_line(v_curtime || 'ERROR while dropping partition ' || v_p_to_archive(i) || ' with statement: ' || v_sql2 ||' - ' || SQLERRM); ROLLBACK; RAISE; END; END LOOP;[/CODE]Ich hoffe ihr könnt mir hier helfen! Danke und Grüße, Chaya [/QUOTE]
Bilder bitte
hier hochladen
und danach über das Bild-Icon (Direktlink vorher kopieren) platzieren.
Zitate einfügen…
Authentifizierung
Der grüne Frosch hüpft über die Hügel an den Bäumen vorbei in die Höhle. Bitte nenne das fünfte Wort!
Antworten
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
SQL-Frage
Oben