Diese Form des INPUT
-Statements wird benutzt, wenn bei der
Eingabeverarbeitung eine mit dem Natural-Map-Editor erstellte Eingabemaske
(Map) verwendet werden soll.
Hierbei gibt es zwei Möglichkeiten:
das Programm enthält keine Parameterliste
das Programm enthält eine Parameterliste (operand1).
INPUT
[WINDOW= 'window-name']
[WITH-TEXT-option]
|
||
[MARK-option] | ||
[ALARM-option] | ||
[USING ] MAP map-name [NO ERASE ]
|
||
operand1 | ||
NO PARAMETER |
Dieses Dokument behandelt folgende Themen:
Eine Erläuterung der in dem Syntax-Diagramm verwendeten Symbole entnehmen Sie dem Abschnitt Syntax-Symbole.
Die folgenden Anforderungen müssen bei der Benutzung von INPUT
USING MAP
ohne Parameterliste erfüllt werden:
Der map-name muss als alphanumerische Konstante (maximal 8 Zeichen lang) angegeben werden.
Die verwendete Map muss bereits erstellt sein, bevor das Programm, das sie referenziert, kompiliert werden kann.
Die Feldnamen werden bei der Kompilierung dynamisch von der Map-Source übernommen. Die Feldnamen müssen in Map und Programm identisch sein.
Zu diesem Zeitpunkt muss auf alle im INPUT
-Statement
referenzierten Felder zugegriffen werden können.
Im Structured Mode müssen die Felder vorher definiert werden, und Datenbankfelder müssen durch Referenzierung der betreffenden Verarbeitungsschleife bzw. des betreffenden Views korrekt referenziert werden.
Im Reporting Mode müssen Benutzervariablen in der Map neu definiert werden.
Wird das Layout der Map verändert, müssen die die Map verwendenden Programme nicht neu katalogisiert werden. Wenn aber Array-Strukturen oder -Namen, Format/Länge von Feldern geändert oder Felder zur Map hinzugefügt bzw. aus ihr gelöscht werden, müssen die die Map verwendenden Programme neu katalogisiert werden.
Die Map-Source muss bei der Programm-Kompilierung zur Verfügung
stehen; sonst kann das INPUT USING MAP
-Statement nicht kompiliert
werden.
Anmerkung:
Wollen Sie das Programm kompilieren, obwohl noch keine Map zur
Verfügung steht, geben Sie NO PARAMETER
an: das INPUT USING
MAP
-Statement kann dann kompiliert werden, auch wenn die Map noch nicht
vorhanden ist.
Wenn Sie Namen der Eingabefelder (operand1) im Programm definieren, müssen diese nicht mit den für die Map verwendeten Feldnamen übereinstimmen.
Die Reihenfolge der Felder im Programm muss allerdings zur Reihenfolge der Felder in der Map passen. Hierbei ist zu beachten, dass der Map-Editor die in der Map definierten Felder in alphabetischer Reihenfolge der Feldnamen sortiert. Näheres hierzu finden Sie in der Map-Editor-Beschreibung in der Editors-Dokumentation.
Das Programm-Editor-Zeilenkommando
.I(mapname)
kann dazu verwendet werden,
ein vollständiges INPUT USING MAP
-Statement mit einer
Parameterliste, die anhand der in der angegebenen Map definierten Felder
generiert wird, zu erstellen.
Wird das Layout der Map verändert, muss das Programm nicht neu katalogisiert werden, es sei denn, in der Map werden Felder gelöscht, hinzugefügt oder umbenannt, Feldformate/-längen geändert oder Array-Strukturen modifiziert.
Bei der Ausführung prüft Natural, ob Format und Länge der Map-Felder in Einklang mit denen der Programm-Felder stehen. Ist dies nicht der Fall, wird eine entsprechende Fehlermeldung ausgegeben.
Operanden-Definitionstabelle:
Operand | Mögliche Struktur | Mögliche Formate | Referenzierung erlaubt | Dynam. Definition | ||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
map-name | C | S | A | U | ja | nein | ||||||||||||||
operand1 | S | A | A | U | N | P | I | F | B | D | T | L | C | ja | ja |
Syntax-Element-Beschreibung:
INPUT WINDOW='window-name' |
Eingabe-Fenster:
Siehe Syntax
1 des |
---|---|
WITH TEXT/MARK/ALARM-options |
Optionen:
Diese Optionen sind unter Syntax 1 des
|
USING MAP map-name |
Name der Eingabemaske:
Mit der Der map-name kann als 1 bis 8 Zeichen
lange alphanumerische Konstante oder in Form einer Benutzervariablen angegeben
werden. Wird eine Variable verwendet, muss diese vorher definiert worden sein.
Die Groß-/Kleinschreibung des Namens wird nicht
verändert. Der Map-Name darf ein Und-Zeichen (&) enthalten; dies
wird dann zur Ausführungszeit durch den aus einem Zeichen bestehenden Code
ersetzt, der dem aktuellen Wert der Systemvariablen
Die Ausführung des |
NO ERASE |
Überlagerte Anzeige:
Siehe Syntax
1 des |
operand1 |
Zu verwendende Felder:
Es können Datenbankfelder oder Benutzervariablen angegeben werden, die jedoch alle vorher definiert worden sein müssen. Die Felder müssen in Anzahl, Reihenfolge Format und Länge und für (Arrays) in der Anzahl der Ausprägungen mit den referenzierten Map-Feldern übereinstimmen, da andernfalls ein Fehler generiert wird. Ändert sich der Wert eines Datenbankfeldes aufgrund einer
|
Sie können den Eingabemodus mit dem Session-Parameter
IM
oder den Terminalkommandos %F
und
%D
ändern.
Der Forms-Modus wird mit dem Terminalkommando
%F
eingeschaltet.
Im Forms-Modus (Profil/Session-Parameter
IM=F
) zeigt
Natural den gesamten Ausgabetext des Map-Layouts Feld für Feld an, und zwar
entsprechend der Positionierungsparameter. Dadurch kann der Benutzer Daten Feld
für Feld eingeben. Wenn alle Daten eingegeben sind, wird eine Hardcopy-Ausgabe
erzeugt, die genau dem Abbild auf dem Bildschirm entspricht.
Im Falle eines Fehlers kann der Benutzer das Terminalkommando
%R
eingeben und sodann
das gesamte Formular erneut eingeben. Die Eingaben werden dann wie bei der
ersten Ausführung des INPUT
-Statements verarbeitet.
Der Keyword/Delimiter-Modus wird mit dem Terminalkommando
%D
eingeschaltet.
In diesem Modus (Profil/Session-Parameter
IM=D
) können Daten 1.)
unter Verwendung von Schlüsselwörtern oder 2.) in Abhängigkeit von
der Position/Reihenfolge der Felder eingegeben werden, wie auf der
folgenden Seite beschrieben.
Der Text, der im Forms-Modus vor einem Feld ausgegeben würde, wird im
Keyword/Delimiter-Modus als Schlüsselwort (Keyword) verwendet, um das
betreffende Feld zu identifizieren. Nach dem Schlüsselwort muss das
Input-Assign-Zeichen stehen (siehe Session-Parameter
IA
) und
unmittelbar danach die Eingabedaten.
Die Eingabedaten werden durch das mit dem Session-Parameter
ID
definierte
Input-Delimiterzeichen voneinander getrennt. Auf ein Input-Assign-Zeichen
folgende Leerzeichen werden als Eingabedaten interpretiert. Nach dem letzten
Datenelement ist kein Input-Delimiterzeichen erforderlich.
Die Reihenfolge der Eingabedaten ist beliebig. Wird ein nicht im
INPUT
-Statement definiertes Schlüsselwort eingegeben, gibt Natural
eine entsprechende Fehlermeldung aus. Es brauchen nicht alle Felder mit
Eingabedaten gefüllt zu werden. Felder, in die nichts eingegeben wird, werden
auf Leerzeichen (alphanumerische Felder) bzw. Null (numerische und hexadezimale
Felder) gesetzt.
Es können auch lediglich Eingabedaten, jeweils durch das gültige
Input-Delimiter-Zeichen (ID
-Parameter)
voneinander getrennt, eingegeben werden. In diesem Fall muss die Reihenfolge
der Eingabedaten der Reihenfolge der Eingabefelder im
INPUT
-Statement entsprechen.
Beide Eingabearten (1 und 2) können auch miteinander kombiniert werden.
Solange keine Schlüsselwörter angegeben werden, ist die im
INPUT
-Statement angegebene Reihenfolge der Felder maßgeblich; wird
ein Schlüsselwort angegeben, so werden die auf das Schlüsselwort folgenden
Eingabedaten dem durch das Schlüsselwort identifizierten Feld zugeordnet.
Folgen hierauf wieder Eingabedaten ohne Schlüsselwörter, so werden diese Daten
den Feldern zugeordnet, die im INPUT
-Statement auf das mit
Schlüsselwort identifizierte Feld folgen.
Anmerkung:
Ein Schlüsselwort und das dazugehörige Eingabefeld müssen sich auf
derselben logischen Zeile befinden. Wenn die Länge beider zusammen die
Zeilenlänge überschreitet, vergrößern Sie die Zeilenlänge (Session-Parameter
LS
)
entsprechend, so dass Schlüsselwort und Feld in eine Zeile passen.
Im Keyword/Delimiter-Modus eingegebene Eingabedaten werden entsprechend der auch im Screen-Modus gültigen Regeln auf ihre Gültigkeit überprüft. Wird versucht, einen Wert einzugeben, der länger als das betreffende Feld ist, so gibt Natural eine entsprechende Fehlermeldung aus.
Werden Daten für ein INPUT
-Statement im
Keyword/Delimiter-Modus von einem gepufferten Terminal (Typ 3270) oder einer
Workstation aus eingegeben, so müssen alle von einem bestimmten
INPUT
-Statement zu verarbeitenden Eingabedaten auf einem einzigen
Schirm eingegeben werden; erst wenn alle Daten eingegeben sind, darf
FREIG gedrückt werden.
Daten, die mittels eines FETCH
-, RUN
- oder STACK
-Statements im Natural-Stack
abgelegt wurden, werden bei der Ausführung des nächsten
INPUT
-Statements als Eingabedaten verarbeitet.
Das INPUT
-Statement verarbeitet die Daten in dem oben
beschriebenen Keyword/Delimiter-Modus.
Felder, für die keine Eingabedaten zur Verfügung stehen, werden je nach Format mit Leerzeichen bzw. Nullen gefüllt. Sind mehr Daten als Eingabefelder vorhanden, so werden überschüssige Eingabedaten ignoriert.
Wenn ein Feld mit Daten aus dem Stack gefüllt wird, gelten die Feldattribute nicht für die Daten.
Über die Natural-Systemvariable *DATA
können Sie erfahren, wieviele Datenelemente gegenwärtig im Natural-Stack zur
Verfügung stehen.
Folgende Themen werden behandelt:
Im Batch-Forms-Modus wird die Eingabe-Map angezeigt. Für jede Zeile,
die ein oder mehrere Eingabefelder (AD=A
oder
AD=M
) enthält, wird ein Datensatz gelesen, und die in
dem Satz enthaltenen Daten werden den entsprechenden Feldern zugeordnet.
Eingabedatenfelder werden als benachbart angesehen. Werden keine
Delimiter-Zeichen verwendet, so müssen die Daten genau den intern definierten
Feldlängen entsprechend eingegeben werden. Bei numerischen Feldern müssen
gegebenenfalls eine Stelle für das Vorzeichen (falls
SG=ON
gesetzt ist) und/oder eine Stelle für das Komma (Dezimalpunkt) berücksichtigt
werden.
Werden Delimiter-Zeichen verwendet, um die Eingabedaten der einzelnen
Felder voneinander zu trennen, so ist dies nicht erforderlich; die Eingabedaten
werden dann jeweils von links nach rechts ab Stelle 1 verarbeitet. Für die
Eingabe der Daten gelten die unter
Eingabe von
Daten als Reaktion auf ein INPUT-Statement beschriebenen
Regeln. Darüber hinaus kann mit dem Zuweisungszeichen für Eingabe-Parameter
(siehe Profil- und Session-Parameter IA
) bewirkt werden,
dass der Inhalt eines *OUTIN
-Feldes nicht
zurückgesetzt wird.
Im Batch-Betrieb gilt für diesen Modus dasselbe wie im TP-Betrieb, allerdings mit folgenden Ausnahmen:
Das Drucken der gesamten Eingabemaske kann über das Terminalkommando
%Q
gesteuert
werden.
*OUTIN
-Felder behalten ihre
ursprünglichen Werte, wenn diese nicht explizit geändert werden.
Folgende Terminalkommandos können verwendet
werden, wenn ein INPUT
-Statement im Batch-Betrieb auf einem
Großrechner verwendet wird:
Terminalkommando | Funktion |
---|---|
%* |
Unterdrückung des nächsten
Eingabedatensatzes:
Wenn in Position 1 oder 2 eines Datensatzes eingegeben, bewirkt
DATA RECORD %* SUPPRESSED DATA RECORD |
% |
Fortsetzung des Datensatzes:
Als letztes Zeichen eines Datensatzes bewirkt
DATA, RECORD, WITH, CONTINUATION, % CONTINUATION RECORD INPUT V1 V2 V3 V4 V5 V6 DISPLAY V1 V2 V3 V4 V5 V6 erzeugt folgende Ausgabe: DATA RECORD WITH CONTINUATION CONTINUATION RECORD |
%/ |
Dateiende-Bedingung:
|
%% |
Restart-Punkte setzen:
Sie können mit dem Terminalkommando %% Restart-Punkte in den Eingabedateien setzen und so die Synchronisation der Eingabedateien im Falle eines Fehlers sicherstellen. |
%. |
Lesen der Eingabewerte beenden:
Lesen der Eingabewerte für das gerade ausgeführte
|
%Knn |
Simulieren von PF-Tasten bzw.
PA-Tasten:
Dadurch können PF-Tastenfunktionen auch im Batch-Betrieb verwendet werden. |
%KPn | |
%Q |
Maskenausgabe im Batch-Betrieb
unterdrücken: Bewirkt, dass Masken, die zum Lesen von
Eingabedaten verwendet werden, nicht mit ausgedruckt werden.
|
Ausführliche Informationen zu den oben genannten Kommandos finden Sie in der Terminalkommandos-Dokumentation.
Zur Verwendung des INPUT
-Statements im Batch-Betrieb ist
zusätzliche JCL erforderlich. Bitte wenden Sie sich an Ihren
Natural-Administrator um sicherzustellen, dass diese JCL bereitgestellt ist,
bevor Sie eine Batch-Ausführung versuchen.