Lock vor Insert oder Update

Getting started ... Alles für einen gelungenen Start.
4 Beiträge • Seite 1 von 1
4 Beiträge Seite 1 von 1

Lock vor Insert oder Update

Beitrag von kbit100 (Specialist / 130 / 42 / 0 ) »
Hallo zusammen,

ich habe einen bestehenden Report geändert, der über einen Sklaven-Report viele Hintergrund-Jobs aufruft, die verschiedene Z-Tabellen mit einer Menge Daten befüllt (ca. 2 Mio. Datensätze insgesamt). Dieser Report (und sein Sklave, dr ja nur die Jobs startet) bzw. seine Jobs sind die einzigen, die diese Z-Tabellen verändern.

Jetzt kriege ich den Report von der Qualitätssicherung um die Ohren gehauen, weil vor den Änderungen in der Datenbank kein "Lock" durchgeführt wird.

Das Tabellensperren wollte ich nach einem Beispiel aus diesem Forum durchführen, etwa so:

Code: Alles auswählen.

data sptab type rstable.

  sptab-TABNAME = 'ZTAB'. "Deine Tabelle
  sptab-VARKEY  = SY-MANDT.

  CALL FUNCTION 'ENQUEUE_E_TABLE'
       EXPORTING
            TABNAME        = sptab-TABNAME
            VARKEY         = sptab-VARKEY
       EXCEPTIONS
            FOREIGN_LOCK   = 1
            SYSTEM_FAILURE = 2
            OTHERS         = 3.
Es sind 6 Z-Tabellen gleichzeitig zu befüllen. Der Report erzeugt über seinen Sklavenreport die Hintergrundjobs, die alle gleichzeitig in diese Tabellen schreiben.

Mal doof gefragt: Muss ich im Report das o.g. ENQEUE_E_TABLE für jede einzelne Tabelle hintereinander aufrufen und kann dann die Jobs starten? Oder gibt es etwas Eleganteres?

Es gibt noch einen Überwachungsjob, der mit den Datenschaufeljobs gleichzeitig gestartet wird. Der wartet, bis der letzte Datenschaufeljob durchgelaufen ist und macht dann ein Update auf eine Protokolltabelle. Kann ich diesen Job dann benutzen, um die zuvor gesetzten Sperren der 6 Tabellen aufheben?

Vielen Dank für jeden Tipp!

Gruß

K.

gesponsert
Stellenangebote auf ABAPforum.com schalten
kostenfrei für Ausbildungsberufe und Werksstudenten


Re: Lock vor Insert oder Update

Beitrag von a-dead-trousers (Top Expert / 4276 / 213 / 1140 ) »
Die Sperren gelten nur solange wie das Programm läuft. Ein anderer Job kann die Sperren nicht aufheben.
Mal blöd gefragt: Werden die Sperren auf diese Tabellen irgendwo sonst noch in eurem System abgefragt? Vorallem da du einen allgemeinen Sperrbaustein verwendest und keine explizites Sperrobjekt für deine Tabellen angelegt hast, zweifle ich sehr daran.
Die SAP-Sperren funktionieren abseits der DB-Locks. Wenn irgendein anderes Programm auf die Tabellen zugreift und die Sperren nicht abfragt kann es trotzdem normal mit den Tabellen arbeiten.
Wenn nur du und in deinen Reports mit den Tabellen arbeitest sind die Sperren unnötig.

lg ADT
Theory is when you know something, but it doesn't work.
Practice is when something works, but you don't know why.
Programmers combine theory and practice: Nothing works and they don't know why.

ECC: 6.18
Basis: 7.50

Re: Lock vor Insert oder Update

Beitrag von ewx (Top Expert / 4784 / 294 / 628 ) »
Ist vielleicht eher gemeint, dass du jeden einzelnen Datensatz sperren sollst, damit dein "Sklavenprogramm" nicht gerade dann Daten ändert, während jemand diesen Datensatz in einer Dialogtransaktion bearbeitet?

Re: Lock vor Insert oder Update

Beitrag von kbit100 (Specialist / 130 / 42 / 0 ) »
Hallo,

in dem Augenblick, in dem die Z-Tabellen befüllt werden, greift kein anderes Programm darauf zu. Geschrieben werden diese Tabellen sowieso von meinem Programm mit seinem Sklaven und den erwähnten Jobs. Ich finde auch, dass eine Sperre nicht notwendig ist, aber sicher kennt ihr auch das Problem einer QS-Abteilung, die eben auf die Einhaltung der SAP-Development-Guides und eigener Richtlinien besteht.

Gruß

K.

Seite 1 von 1

Vergleichbare Themen

3
Antw.
367
Views
Update oder Insert
von ABAPlerv » 16.08.2022 12:11 • Verfasst in ABAP® für Anfänger
0
Antw.
1298
Views
5
Antw.
2121
Views
LOCK Statement
von DoGaS » 22.03.2006 15:28 • Verfasst in ABAP® Core
9
Antw.
8615
Views
DBTab Update from Table oder in Loop mit "Update Set" Oder ?
von RIG » 09.03.2018 11:27 • Verfasst in ABAP® Core
5
Antw.
1045
Views
Insert bei Read
von L0w-RiDer » 09.04.2019 15:46 • Verfasst in ABAP® für Anfänger

Über diesen Beitrag


Unterstütze die Community und teile den Beitrag für mehr Leser und Austausch

Aktuelle Forenbeiträge

E-Mail versenden mit GroupWise 18
vor einer Stunde von a-dead-trousers 3 / 292
PDF-Anzeige unter EDGE
vor 5 Tagen von jocoder 2 / 73

Newsletter Anmeldung

Keine Beiträge verpassen! Wöchentlich versenden wir lesenwerte Beiträge aus unserer Community.
Die letzte Ausgabe findest du hier.
Details zum Versandverfahren und zu Ihren Widerrufsmöglichkeiten findest du in unserer Datenschutzerklärung.

Aktuelle Forenbeiträge

E-Mail versenden mit GroupWise 18
vor einer Stunde von a-dead-trousers 3 / 292
PDF-Anzeige unter EDGE
vor 5 Tagen von jocoder 2 / 73

Unbeantwortete Forenbeiträge

Zwischensumme Adobe Forms
vor 4 Wochen von Lucyalison 1 / 132
Group Items auf einer Filterbar
vor 4 Wochen von Bright4.5 1 / 166