250 likes | 405 Views
Übung 4 Reports mit Datenbankzugriff. Komplexe Typen. Strukturen Geschachtelte und nicht-geschachtelte Strukturen. Flache und tiefe Strukturen. Interne Tabellen. Strukturen. TYPES|DATA : BEGIN OF structure, k1 { TYPE type| LIKE dobj}..,
E N D
Komplexe Typen • Strukturen • Geschachtelte und nicht-geschachtelte Strukturen. • Flache und tiefe Strukturen. • Interne Tabellen
Strukturen • TYPES|DATA: BEGIN OF structure, k1 {TYPE type|LIKE dobj}.., k2 {TYPE type|LIKE dobj}.., ....... kn {TYPE type|LIKE dobj}.., END OF structure.
Interne Tabellen • den Zeilentyp, der ein beliebiger elementarer Typ, ein Referenztyp oder komplexer Datentyp sein kann. • einen Schlüssel, welcher der Identifikation von Tabellenzeilen dient. Er läßt sich aus den elementaren Feldern der Zeilen aufbauen. Wir unterscheiden weiterhin zwischen eindeutigen und nicht eindeutigen Schlüsseln. TYPES|DATA <t> TYPE|LIKE <tabkind> OF <linetype> [WITH <key>].
Tabellenart Standard Tabelle Sortier Tabelle Hash-Tabelle Beispiel: DATA itab TYPE HASHED TABLE OF ZKUNDEN WITH UNIQUE KEY kundennr name .
Standard-Tabellenobjekte Kurzformen der DATA-Anweisung DATA <itab> TYPE|LIKE [STANDARD] TABLE OF <linetype>. DATA <itab> TYPE|LIKE [STANDARD] TABLE OF <linetype> WITH DEFAULT KEY. Diese beiden DATA-Anweisungen werden vom System automatisch zur folgenden Anweisung vervollständigt: DATA <itab> TYPE|LIKE STANDARD TABLE OF <linetype> WITH NON-UNIQUE DEFAULT KEY.
Tabellenarbeitsbereich DATA wa_dbtab TYPE|LIKE dbtab. Dabei ist dbtab eine Datenbanktabelle, ein View oder eine flache Struktur.
Open-SQL • Data Manipulation Languge (DML) • Data Defintion Language • Data Control Language
Daten aus Datenbanktabellen lesen SELECT was [Auswahlfelder] FROM woher [Datenbanktabelle] INTO wohin [Ziel] WHERE Bedingung
SELECT-Anweisung und SELECT-Schleife SELECT-Anweisung • SELECT SINGLE • INTO CORRESPONDING FIELDS OF TABLE itab SELECT-Schleife • SELECT ........ ........ ENDSELECT
SELECT SINGLE DATA wa_name LIKE zkunden-name, wa_vorname LIKE zkunden-vorname . SELECT SINGLE name vorname FROM zkunden INTO (wa_name , wa_vorname) WHERE kundennr = '124456' . WRITE: wa_name , wa_vorname .
SELECT SINGLE DATA wa_kunden LIKE zkunden . SELECT SINGLE * FROM zkunden INTO wa_kunden WHERE kundennr = '124456' . WRITE: wa_kunden-name , wa_kunden-vorname .
SELECT-Schleife DATA: wa_name LIKE zkunden-name,wa_vorname LIKE zkunden-vorname . SELECT name vorname FROM zkunden INTO (wa_name , wa_vorname) WHERE wohnort = 'Regensburg' . WRITE:/ wa_name , wa_vorname . ENDSELECT.
APPEND, LOOP APPEND wa TO itable LOOP AT itable INTO a-bereich . < Bearbeiten des Datensatzes im Arbeitsbereich > ENDLOOP.
Daten aus Datenbanktabellen lesen DATA: wa_kunden LIKE zkunden,it_kunden LIKE TABLE OF zkunden. SELECT name vorname FROM zkunden INTO CORRESPONDING FIELDS OF TABLE it_kunden WHERE wohnort = 'Regensburg' . LOOP AT it_kunden INTO wa_kunden. WRITE :/ wa_kunden-name, wa_kunden-vorname. ENDLOOP.
Aggregate einzelner Spalten lesen • MAX: liefert den Maximalwert der Spalte • MIN: liefert den Minimalwert der Spalte • AVG: liefert den Durchschnittswert der Spalte • SUM: liefert die Summe der Spalte • COUNT: zählt Werte oder Zeilen wie folgt • COUNT( DISTINCT <si>) liefert die Anzahl unterschiedlicher Werte in der Spalte <s i >. COUNT( *) liefert die gesamte Anzahl der Zeilen in der Ergebnismenge
Klauseln • GROUP BY, um mehrere Zeilen beim lesen in eine Zeile zu verdichten • HAVING, um Bedingungen für verdichtete Zeilen anzugeben • ORDER BY, um Zeilen beim Einlesen zu sortieren • ORDER BY <s1> [ASCENDING|DESCENDING] <s2> [ASCENDING|DESCENDING]...
Beispiel DATA: wa_zwkn TYPE zkurse-wkn, minimum TYPE p DECIMALS 2, maximum TYPE p DECIMALS 2. select wkn min( kurs ) max( kurs ) into (wa_zwkn, minimum, maximum) from zkurse group by wkn. WRITE: / wa_zwkn, minimum, maximum. ENDSELECT.
REFRESH, CLEAR, SORT, Textelemente • REFRESH itable • CLEAR variable • SORT itable BY f1 f2 ...[ASCENDING] [DESCENDING] • Textelemente • Sy-subrc
Übungen Reports mit Datenbankzugriff
Open-SQL: SELECT, Textelemete Erstellen Sie für OOB 25 eine Übersicht über alle Depotkunden als Report ZKUNDEN_REGENSBURG_**, die ihren Wohnsitz in Regensbug haben. Die Übersicht soll die Kundennummer, Name, Vorname sowie Wohnort des Kunden aus der Tabelle ZKUNDEN enthalten und nach Kundennummer aufsteigend sortiert sein.
Kursentwicklung mit SELECT SINGLE Die Wertpapierinhaber wünschen eine Aufstellung über die Kursentwicklung in ansprechender Form (siehe unten). Programmieren Sie hierzu einen Report ZKURSE_**.
Interne Tabelle, APPEND, SORT, LOOP Legen Sie in einem Report ZDEPOTPOSTEN_** eine interne Tabelle an, welche die Daten der Datenbanktabelle ZDEPOTPSTN enthält. Sortieren Sie die interne Tabelle nach der WKN aufsteigend. Innerhalb gleicher WKN sortieren Sie nach der Anzahl absteigend. Geben Sie die interne Tabelle auf dem Bildschirm aus.