Freigeben über


Syntax für X++

Hinweis

Community-Interessensgruppen sind jetzt von Yammer zu Microsoft Viva Engage gewechselt. Um an einer Viva Engage-Community teilzunehmen und an den neuesten Diskussionen teilzunehmen, füllen Sie das Formular "Anfordern des Zugriffs auf Finance and Operations Viva Engage Community" aus , und wählen Sie die Community aus, der Sie beitreten möchten.

Dieser Artikel enthält die Syntaxreferenz für X++.

X++-Schlüsselwörter

Die in der folgenden Tabelle gezeigten X++-Schlüsselwörter sind reserviert. Diese Schlüsselwörter können nicht für andere Zwecke verwendet werden.

Reserviertes Wort Description Verwandte Informationen
! Nicht. Relationale Operatoren
!= Ungleichheitsoperator (ungleich). Relationale Operatoren
# Präfix für Makronamen. Vorgehensweise: Verwenden von #define und #if zum Testen eines Makros
& Binär UND. Arithmetische Operatoren
&& LogischeS UND. Relationale Operatoren
( Funktionsaufrufoperator, der den Anfang des Funktionsaufrufs angibt.
) Funktionsaufrufoperator, der das Ende des Funktionsaufrufs angibt.
* Multiplizieren. Das Sternchen (*) wird auch in X++ SQL verwendet. Eine Verwendung besteht darin, alle Felder aus den Tabellen in einer select Anweisung zu kennzeichnen. Eine weitere Verwendung ist als Wildcard mit dem like Operator, um 0 für viele Zeichen jeder Art zu kennzeichnen. Der like Operator verwendet auch das Zeichen ? Arithmetische Operatoren
^ Binärer XOR. Arithmetische Operatoren
| Binär ODER. Arithmetische Operatoren
|| LogischeS ODER. Relationale Operatoren
~ Nicht. Arithmetische Operatoren
+ Plus. Arithmetische Operatoren
++ Zunahme. Zuordnungsoperatoren
+= Additive Zuordnung. Zuordnungsoperatoren
, Kommaoperator. Durch Kommas getrennte Ausdrücke werden sequenziell von links nach rechts ausgewertet.
- Minus. Arithmetische Operatoren
-- Dekrementierungsoperator. Zuordnungsoperatoren
-= Subtrahierende Zuordnung. Zuordnungsoperatoren
. Der Zugriffsoperator des Klassenelements greift z formRun.run . B. auf die run Methode eines Objekts des Klassentyps FormRunzu.
/ Teilen. Arithmetische Operatoren
\ Escapezeichen in Zeichenfolgen. Escapes zusätzliche Anführungszeichen und bestimmte Buchstaben wie "\t" für die Registerkarte.
@ Escape von Schlüsselwörtern. Es kann beispielsweise nicht kompiliert werden, ohne dass das var @str = 1@abstract; Zeichen, das eine Zeichenfolge folgt, @ als Bezeichner angesehen wird. Sie wirkt sich auch auf Literalzeichenfolgen aus, indem der Effekt des \Escapezeichens negiert wird und die Zeichenfolge mehrere Zeilen im Quellcode umfassen kann. Die neue Zeile wird durch ein Zeichen hexadezimaler 0x0A dargestellt, das häufig als Linienvorschub bezeichnet wird. Es ist kein Wagenrücklaufzeichen für hexadezimale 0x0D enthalten, wie in 0x0D0A.
: Das Doppelpunktzeichen (:) wird verwendet, um Groß-/Kleinschreibungswerte in der switch Anweisung zu trennen.
:: Wird verwendet, um statische Methoden (Klassen) aufzurufen: ClassName::methodName() und zum Festlegen von Enumerationsliteralen wie NoYes::Yes.
; Beendet Anweisungen. Wird in for Schleifen oder als Trennzeichen von Initialisierungs-, Aktualisierungs- und Wertüberprüfungsteilen verwendet.
< Weniger als. Relationale Operatoren
<< Linke Schicht. Arithmetische Operatoren
<= Kleiner oder gleich. Arithmetische Operatoren
= Zuordnungsoperator. Das Argument links von "=" wird auf den Wert des Arguments rechts festgelegt. Zuordnungsoperatoren
== Gibt true zurück, wenn die Ausdrücke gleich sind. Relationale Operatoren
> Größer als. Relationale Operatoren
>= Größer oder gleich. Relationale Operatoren
>> Bitweise rechte Umschalttaste. Dieser Operator verschiebt Bits auf der linken Seite um den Betrag auf der rechten Seite. Jede Schicht dividiert die Zahl effektiv durch 2^n, wobei n die Anzahl der verschobenen Positionen ist. Arithmetische Operatoren
?: Ternärer Operator Das Fragezeichen (?) wird auch vom like Operator verwendet, um genau ein Zeichen beliebiger Art zu kennzeichnen. Der like Operator verwendet auch das Zeichen. Ternäre Operator (?)
[ Array-Deklarator, geöffnet. Muss mit "]" verwendet werden.
] Array-Deklarator, schließen. Muss mit "[" verwendet werden.
{ Startet eine zusammengesetzte Anweisung, die wiederum null oder mehr Anweisungen enthalten kann. Die zusammengesetzte Anweisung endet mit dem nächstgelegenen übereinstimmenden "}".
} Gibt das Ende der oben beschriebenen Zusammengesetzten Anweisung an. Vor der ersten dieser Anweisungen muss ein "{" angezeigt werden.
abstract Klassen- und Methodenmodifizierer. Eine abstrakte Klasse kann nicht mit dem neuen Schlüsselwort erstellt werden – nur die von ihr abgeleiteten Klassen können. Eine abstrakte Methode kann nicht aufgerufen werden, nur Methoden, die sie außer Kraft setzen. Eine Tabelle kann als abstrahiert geändert werden, indem sie die Abstrakte Eigenschaft in der AOT oder mithilfe der Klasse auf DictTable" festlegt. Die Abstrakte Eigenschaft ist standardmäßig "Nein" und kann nur festgelegt werden, wenn die Tabelle durch eine andere Tabelle erweitert wird. Jede Zeile in einer abstrakten Tabelle muss eine abhängige Zeile in einer abgeleiteten Tabelle aufweisen. Dies bedeutet, dass jede Zeile in einer abstrakten Tabelle einen Wert größer als Null im InstanceRelationType-Eigenschaftenfeld hat. Es gibt keine anderen Effekte vom Markieren einer Tabelle als abstrakt. Informell verwenden Programmierer häufig den Begriff Konkretes , um eine Klasse zu beschreiben, die nicht abstrakt ist. Übersicht über Methodenmodifizierertabellenvererbung
anytype Ein Typ, der Werte eines beliebigen Typs enthalten kann. Anytype
wie Erforderlich, wenn Sie einer abgeleiteten Klassenvariable eine Basisklassenvariable zuweisen. Bei einer Klasse, die eine Derived Klasse Base, vermeidet die Anweisung myDerived = myBase as Derived; beispielsweise einen Compilerfehler, indem das Schlüsselwort verwendet wird. Dieses Schlüsselwort gilt auch, wenn Sie einer abgeleiteten Tabellenvariable eine Basistabellenvariable zuweisen. Wenn der Wert (myBase) nicht vom angegebenen Typ (abgeleitet) ist, gibt der Ausdruck NULL zurück. Ausdrucksoperatoren: Ist und wie vererbung
Asc Eine Option für die orderby Oder-Klausel groupby in einer select Anweisung. Die Sortierung ist aufsteigend. Select-Anweisungssyntax
at Gibt die Position eines Druckfensters als Teil einer print Anweisung an. Die Print-Anweisung sollte nicht verwendet werden. Print-Anweisungen
Avg Gibt den Mittelwert der Felder aus den Zeilen zurück, die durch die group by Klausel in einer select Anweisung angegeben werden. Select-Anweisungssyntax
break Sofortiges Beenden eines iterativen Codeblocks. Break-Anweisungen
Haltepunkt Stellt einen Haltepunkt dar, der für Debuggingzwecke festgelegt ist. Um einen Haltepunkt in Ihrem Code festzulegen, schreiben Sie Folgendes: breakpoint;
bis Teil eines reservierten Ausdrucks, z. B. gruppieren nach und nach.
byref Gibt an, dass der parameter, der an die aufgerufene Methode übergeben wird, durch Verweis (Adresse) anstelle des Werts übergeben wird. Byref wird in X++ verwendet, wenn eine .NET-Methode aufgerufen wird, die einen Parameter anhand eines Verweises verwendet (z. B. mit den C#-Schlüsselwörtern out oder ref). How to: Use the byref Keyword for CLR Interop.
case Auswahl innerhalb einer switch Anweisung. Switch-Anweisungen
fangen Wird in der Ausnahmebehandlung verwendet. Ausnahmebehandlung mit "Try" und "Catch Keywords"
changeCompany Ändert Datenbankeinstellungen in ein anderes Unternehmen. Ändern des Firmenentwurfsmusters
Klasse Deklariert eine Klasse. Klassen in X++
Klient Methodenmodifizierer. Diese Modifizierer werden nicht mehr verwendet. Alle Methoden werden auf der Serverebene ausgeführt. Methodenmodifizierer
Container Legt den container Typ fest. Container enthalten eine Abfolge von Atomwerten und anderen Containern. Behälter
continue Erzwingt die nächste Iteration einer Schleife. Continue-Anweisungen
anzahl Gibt die Anzahl der Datensätze aus den Zeilen zurück, die durch die group by Klausel in einer select Anweisung angegeben wurden. Select-Anweisungssyntax
crossCompany Bewirkt, dass eine select Anweisung Daten für alle Unternehmen zurückgibt, von denen der Benutzer zum Lesen autorisiert ist. Unternehmensübergreifende X++-Codegrundlagen
date Gibt eine Variable vom Typ datean. Datumsangaben
Vorgabe Standardfall innerhalb von switch Anweisungen. Der Codeblock im Standardteil wird ausgeführt, wenn der Switchwert keiner der case in der switch Anweisung angegebenen Klauseln entspricht. Switch-Anweisungen
delegate Ein Klassenmemmemm, der mehrere Verweise auf Methoden in anderen Klassen speichern kann, und alle diese Methoden aufzurufen, wenn Sie dazu aufgefordert werden. Ein Delegat kann Verweise auf verschiedene Arten von Methoden speichern, einschließlich der folgenden:
  • Statische Methoden für X++-Klassen
  • Instanzmethoden für X++-Klassen
  • Methoden für .NET Framework-Klassen
Ereignisterminologie und Schlüsselwörter X++, C#-Vergleich: Ereignis
delete_from Ermöglicht das Löschen von Datensätzen aus der Datenbank. delete_from
Desc Eine Option für die order by Oder-Klausel group by in einer select Anweisung. Die Sortierung ist absteigend. Select-Anweisungssyntax
zeigen Methodenmodifizierer. Eine Anzeige<-/Anzeigemethode> wird verwendet, um berechnete Werte in einem Formularsteuerelement anzuzeigen. Im Gegensatz zu regulären Feldern werden diese Werte nicht in der Datenbank gespeichert, sondern dynamisch berechnet. Methodenmodifizierer
div Ganzzahlige Division. Arithmetische Operatoren
tun Anfang einer do...while Schleife. Tun... while Loops
edit Methodenmodifizierer. Mit einer edit Methode in X++ können Benutzer Werte in einem Formularsteuerelement ändern, während benutzerdefinierte Logik ausgeführt wird. Im Gegensatz zu display Methoden, die nur berechnete Werte anzeigen, ermöglichen Bearbeitungsmethoden sowohl das Anzeigen als auch das Bearbeiten. Methodenmodifizierer
else (andernfalls) Bedingte Ausführung (if...else). Der else Teil der if Anweisung wird ausgeführt, wenn der Ausdruck in der if-Anweisung ausgewertet wird false wenn und wenn ... else-Anweisungen
eventHandler Muss jedes Mal verwendet werden, wenn Sie entweder einen Methodenverweis von einem Delegaten mithilfe des += Operators -= hinzufügen oder löschen. Beispiel: myDelegate += eventHandler(OtherClass::myStaticMethod); Ereignisterminologie und Schlüsselwörter X++, C#-Vergleich: Ereignis
existiert Wird mit join Klauseln in select Anweisungen verwendet. Select-Anweisungssyntax
Erweitert Eine Klassen- oder Schnittstellendeklarationsklausel. Wenn Ihre Klasse keine weitere Klasse explizit erweitert, wird ihre Klasse als Erweiterung der Object Klasse betrachtet (als ob Sie "Extend Object" geschrieben haben). Erstellen einer Unterklasse
FALSCH Boolescher Literal. Boolesche Werte
Finale Klassen- und Methodenmodifizierer. Gibt an, dass diese Methode nicht überschrieben werden kann. Methodenmodifizierer
firstFast Wird in select Anweisungen verwendet, um den Abruf für die erste Zeile zu beschleunigen. Select-Anweisungssyntax
firstOnly Wird in select Anweisungen verwendet, um nur den ersten Datensatz abzurufen. Das firstOnly Schlüsselwort garantiert nicht, dass ein maximaler Datensatz von einer X++-SQL-Anweisung select abgerufen wird. Wenn der AOS den EntireTable Cache verwenden kann, um die Datenanforderungen der select Anweisung zu erfüllen, wird das firstOnly Schlüsselwort ignoriert. Select-Anweisungssyntax Set-based Caching
firstOnly10 Identisch mit firstOnly, mit Ausnahme von 10 Zeilen statt einer.
firstOnly100 Identisch mit firstOnly, mit Ausnahme von 100 Zeilen statt einer.
firstOnly10000 Identisch mit firstOnly, mit Ausnahme von 1.000 Zeilen anstelle einer Zeile.
flush Löscht den gesamten Tabellencache. Dies kann hilfreich sein, wenn Sie sicherstellen möchten, dass alle an der Tabelle vorgenommenen Änderungen sofort in nachfolgenden Vorgängen widerzuspiegeln sind. Set-based Caching
for Zur Schleifeniteration. Für Schleifen
forceLiterals Wird in select Anweisungen verwendet, um tatsächliche Werte anzuzeigen, die in where Klauseln für die Microsoft SQL Server-Datenbank zum Zeitpunkt der Optimierung verwendet werden. Select-Anweisungssyntax
forceNestedLoop Erzwingt die SQL Server-Datenbank, einen geschachtelten Schleifenalgorithmus zu verwenden, um eine bestimmte SQL-Anweisung zu verarbeiten, die eine join. Select-Anweisungssyntax
forcePlaceholders Wird in select Anweisungen verwendet, um den Kernel anzuweisen, die tatsächlichen Werte, die in where Klauseln in der Microsoft SQL Server-Datenbank zum Zeitpunkt der Optimierung verwendet werden, nicht anzuzeigen. Select-Anweisungssyntax
forceSelectOrder Erzwingt die SQL Server-Datenbank den Zugriff auf die Tabellen in einer Verknüpfung in der angegebenen Reihenfolge. Select-Anweisungssyntax
forUpdate Wählt Datensätze exklusiv für die Aktualisierung aus. Der Vorgang, der für die abgerufenen Datensätze ausgeführt werden soll, ist eine Aktualisierung. Je nach zugrunde liegender Datenbank sind die Datensätze möglicherweise für andere Benutzer gesperrt. Select-Anweisungssyntax
from Teil einer select Anweisung. Die from Klausel gibt den Tabellenpuffer an, in dem die Spalten vorhanden sind. Select-Anweisungssyntax
group Teil der group by Klausel in einer select Anweisung. Select-Anweisungssyntax
if Bedingte Ausführung. wenn und wenn ... else-Anweisungen
Implementiert Implementierung einer interface. Übersicht über Schnittstellen
insert_recordset Kopiert Daten aus einer oder mehreren Tabellen in eine resultierende Zieltabelle auf einem einzelnen Servertrip. insert_recordset
int Gibt eine Variable vom Typ integer (32-Bit) an. Ganze Zahlen
int64 Gibt eine Variable vom Typ integer (64-Bit) an. Ganze Zahlen
interface Schnittstellendeklaration. Übersicht über Schnittstellen
is Fragt, ob das Objekt, auf das von einer Klassenvariable verwiesen wird, entweder von der angegebenen Klasse erbt oder von der angegebenen Klasse ist. Wenn beispielsweise eine Derived Klasse, die eine Klasse Base, gibt der Ausdruck (myDerived is Base)"true" zurück. Dieses Schlüsselwort gilt für klassenvererbung und Tabellenvererbung. Ausdrucksoperatoren: Ist und wie vererbung
join Tabellen werden in Spalten verknüpft, die für beide Tabellen gemeinsam sind. Sie können ein einzelnes Resultset basierend auf mehreren Tabellen mithilfe von Verknüpfungen generieren. Select-Anweisungssyntax
mögen Testet nach Mustern auf Übereinstimmungen mit den Wildcardsymbolen '*' und '?'. Relationale Operatoren
maxof Gibt das Maximum der Felder aus den Zeilen zurück, die durch die group by Klausel angegeben werden. Select-Anweisungssyntax
Minof Gibt das Minimum der Felder aus den Zeilen zurück, die durch die group by Klausel angegeben werden. Select-Anweisungssyntax
mod Gibt den ganzzahligen Rest des linken Ausdrucks1 dividiert durch den rechten Ausdruck2 zurück. Informell wird dies manchmal als Modulooperator bezeichnet. (12 mod 7) == 5 ist wahr.
Neu Operator. Erstellt eine Instanz einer Klasse oder weist Speicher für ein Array zu.
next Ruft den nächsten Datensatz in einer Tabelle ab oder ruft die nächste Methode in einer Kette von Befehlssequenzen auf.
noFetch Gibt an, dass jetzt keine Datensätze abgerufen werden sollen. Select-Anweisungssyntax
notExists Wird mit join Klauseln in select Anweisungen verwendet. Select-Anweisungssyntax
null Symbolische Konstante.
optimistischLock Erzwingt die Ausführung einer Anweisung mit optimistischem Parallelitätssteuerelement, auch wenn ein anderer Wert für die Tabelle festgelegt ist. Select-Anweisungssyntax
Bestellung Teil der order by Klausel in einer select Anweisung. Select-Anweisungssyntax
äußere äußere Verknüpfung. Select-Anweisungssyntax
pause Hält die Ausführung eines Auftrags an. Der Benutzer wird aufgefordert, anzugeben, ob die Ausführung fortgesetzt werden soll. Sie sollten diese Anweisung nicht im Produktionscode verwenden. Select-Anweisungen
pessimisticLock Erzwingt die Ausführung einer Anweisung mit pessimistischem Parallelitätssteuerelement, auch wenn für die Tabelle ein anderer Wert festgelegt ist. Select-Anweisungssyntax
print Ermöglicht das Anzeigen der Ausgabe auf dem Bildschirm. Sie sollten diese Anweisung nicht im Produktionscode verwenden. Print-Anweisungen
privat Methodenzugriffsmodifizierer. Die Methode kann nur innerhalb der Klasse verwendet werden, die die Methode deklariert. Methodenzugriffssteuerung
geschützt Methodenzugriffsmodifizierer. Die Methode kann aus Methoden in der Klasse verwendet werden, die die Methoden deklarieren, und in allen abgeleiteten Klassen. Methodenzugriffssteuerung
Öffentlich Methodenzugriffsmodifizierer. Die Methode kann von jeder Klasse aufgerufen werden. Methodenzugriffssteuerung
echte Legt den real Typ fest, einen Dezimaltyp ohne Rundungsfehler. Realen
RepeatableRead Gibt an, dass keine anderen Transaktionen Daten ändern können, die von Logik innerhalb der aktuellen Transaktion gelesen wurden, bis nach Abschluss der aktuellen Transaktion. Eine explizite Transaktion wird entweder bei ttsAbort oder am äußersten ttsCommit abgeschlossen. Bei einer eigenständigen Select-Anweisung ist die Transaktionsdauer die Dauer des Auswahlbefehls . Die Datenbank erzwingt jedoch manchmal das Äquivalent von repeatableRead in einzelnen Select-Anweisungen , auch ohne dass dieses Schlüsselwort im X++-Code angezeigt wird (je nachdem, wie sich die Datenbank entscheidet, die Tabellen zu scannen). Weitere Informationen finden Sie in der Dokumentation zum zugrunde liegenden relationalen Datenbankprodukt.
wiederholen Wird in der Ausnahmebehandlung verwendet. Ausnahmebehandlung mit "Try" und "Catch Keywords"
Rückgabe Gibt aus einer Methode zurück. Methodendeklaration
reverse Datensätze werden in umgekehrter Reihenfolge zurückgegeben. Select-Anweisungssyntax
select Die select Klausel bestimmt, welche Spalten oder Ansichten im Resultset angezeigt werden. Select-Anweisungen
Server Methodenmodifizierer. Dieser Modifizierer wird ignoriert und sollte nicht verwendet werden, da alle Methoden auf der Serverseite ausgeführt werden. Methodenmodifizierer
Einstellung Wird mit dem Befehl update_recordset verwendet. update_recordset
statisch Statische Methoden verweisen möglicherweise nicht auf Instanzvariablen (nur auf statische Variablen); kann mithilfe des Klassennamens anstelle einer Instanz der Klasse ("MyClass.aStaticProcedure") aufgerufen werden. Methodenmodifizierer
str Legt den string Typ fest. Streichinstrumente
Summe Gibt die Summe der Felder aus den Zeilen zurück, die durch die group by Klausel in einer select Anweisung angegeben werden. Select-Anweisungssyntax
super Ruft die Methode auf, die von der aktuellen Methode überschrieben wurde. Table-Methoden
Schalter Switch-Anweisung. Switch-Anweisungen
tableLock Obsolet; tableLock ist nicht mehr verfügbar.
das Ein Verweis auf die aktuelle Instanz der Klasse. Wird in X++-Code innerhalb einer Instanzmethode der Klasse verwendet. Wird verwendet, um auf Methodenmmber der Klasse zu verweisen.
werfen Wird in der Ausnahmebehandlung verwendet. Ausnahmebehandlung mit "Try" und "Catch Keywords"
STIMMT Boolescher Literal. Boolesche Werte
versuchen Wird in der Ausnahmebehandlung verwendet. Ausnahmebehandlung mit "Try" und "Catch Keywords"
ttsAbort Rollback (d. h. Verwerfen) aller Änderungen in der aktuellen Transaktion. Transaktionsintegrität
ttsBegin Markiert den Anfang einer Transaktion. Transaktionsintegrität
ttsCommit Markiert das Ende einer Transaktion, wobei die Änderungen an den Tabellen committ werden. Transaktionsintegrität
update_recordset Ermöglicht die Manipulation von Zeilensätzen innerhalb eines Vorgangs. update_recordset
validTimeState Filtert Zeilen, die aus einer gültigen Zeitzustandstabelle durch eine X++-SQL-Anweisung select abgerufen werden. Beispiel: select validTimeState(myDateEffective) * from xMyTable; ... oder... select validTimeState(myDateFrom, myDateTo) * from xMyTable; Auswirkungen gültiger Zeitstatustabellen auf Lese- und Schreibvorgänge
Leere Identifiziert eine Methode, die keinen Wert zurückgibt. Methodendeklaration
where Teil einer select Anweisung. Die where Klausel gibt die bedingungen an, die erfüllt werden sollen, d. h. die Zeilen, die Sie in das Ergebnis aufnehmen möchten. Select-Anweisungssyntax
während Iterationsanweisung. Führt eine Anweisung wiederholt aus, solange die Testbedingung erfüllt ist. While loops while select Statements
Fenster Ermöglicht es Ihnen, die Größe des Ausgabefensters zu ändern. Wird mit Druck<-/Druckanweisungen> verwendet, die im Produktionscode nicht empfohlen werden. Print-Anweisungen

Ausdruckssyntax

Ein Ausdruck in X++ wird entweder auf mathematische oder logische Weise verwendet. Ausdrücke basieren auf den Datentypen der Sprache; d. h., ein Ausdruck gibt immer einen Wert eines Typs zurück. Dieser Wert kann in Berechnungen, Zuordnungen, bedingten Anweisungen usw. verwendet werden.

EBNF-Beschreibung von Ausdrücken in X++

Begriff   Definition
Ausdruck = Simple-Expression [RelationalOperator Simple-expression ]
RelationalOperator = =
Einfacher Ausdruck = Einfacher Ausdruck [ +
Begriff = Compfactor { Mult-operator CompFactor }
Mult-Operator = *
CompFactor = [ ! ] [ -
Faktor = Literal
Enum = EnumName :: Literal
Variable = Identifier [ Ausdruck ] ] [ . Ausdruck ]
FunctionCall = [ Ausdruck (.
If-Expression = Ausdruck? Ausdruck: Ausdruck

Semantische Einschränkungen gelten für die vorherige Syntax. Sie können keine Methode mit dem Operator :: aufrufen. Ebenso können Sie das Schlüsselwort nicht ohne ein aktives Objekt verwenden. das heißt, wenn Sie sich nicht innerhalb einer Instanzmethode befinden usw.

Examples

Beispiel für einen Ausdruck Description
1 Ein ganzzahliges Literal.
NoYes::No Ein Enumerationsverweis.
A Ein Variablenverweis.
Schuldner::Find("1") Ein statischer Methodenaufruf (gibt eine Kundenvariable zurück).
(A > 3 ? true : false) Ein If-Ausdruck, der wahr oder falsch zurückgibt.
(wählen Sie CustTable where CustTable.Account == "100"). NameRef Ein Auswahlausdruck. Gibt das Nameref-Feld in der Kundentabelle zurück. Dies ist eine Zeichenfolge.
A >= B Ein logischer Ausdruck. Gibt wahr oder falsch zurück.
A + B Ein arithmetischer Ausdruck. Summiert A und B.
A + B / C Berechnet B/C und fügt dies dann zu A hinzu.
~A + this. Value() Summiert binär nicht A und das Ergebnis des Methodenaufrufwerts für das Objekt im Bereich (dies).
Schuldner::Find("1"). NameRef Gibt das NameRef-Feld des gefundenen Kundendatensatzes zurück.
Schuldner::Find("1"). Saldo() Ein Methodenaufruf Balance in der Kundentabelle (Schuldner::Find gibt einen Kunden zurück). Gibt den Saldo des Kunden mit Kontonummer 1 zurück.

EBNF Übersicht

Extended Backus Naur Form (EBNF) ist eine Metallanguage und wird in diesem Leitfaden verwendet, um die Sprachsyntax zu beschreiben. Eine EBNF-Definition besteht aus Produktionsregeln, Nichtterminals und Terminals. Die wichtigsten Begriffe werden in der folgenden Tabelle angezeigt.

Schlüsselbegriffe Example Description
Terminals Work_Team Ein Terminal ist ein Zeichen oder eine Zeichenfolge von Zeichen, die sich nie ändern.
Nonterminals Employee Ein Nichtterminal ist eine Beschreibung eines Teils eines gültigen Satzes in der Sprache, die entweder durch eine Produktionsregel oder eine Textbeschreibung definiert wird. Ein Nichtterminalsymbol kann immer auf ein oder mehrere Terminalsymbole erweitert werden.
Produktionsregeln Mitarbeiter = Entwickler Prüfer

Example

Work_Team = Leitender Mitarbeiter {, Mitarbeiter} Mitarbeiter = Entwickler | Tester In diesem Beispiel wird eine Work_Team definiert, die aus einem Manager und einem oder Employeesmehreren besteht. Ein Employee ist als ein Developer, oder ein Tester. Die im Beispiel verwendeten Symbole werden in der folgenden Tabelle beschrieben.

Sondersymbole in EBNF

Symbol Description
(Ausdruck) Klammern halten die Symbole (Terminals und Nichtterminals) zusammen. Sie können an einer beliebigen Stelle auf der rechten Seite einer Produktionsregel platziert werden.
Ausdruck1 Ausdruck2
[Ausdruck] Optional: Die Elemente zwischen [ und ] sind optional. Alle oder keines der Elemente in den Klammern ist enthalten.
{Ausdruck} Wiederholen: Die Elemente zwischen { und } sind optional, können aber so oft wie nötig wiederholt werden.

Wenn das Zubehör, das Sie für Ihr Fahrrad kaufen, z. B. aus einem Sattel, Wasserflaschenhaltern, Glocken und Hörnern besteht und Sie entweder eine Glocke oder ein Horn haben könnten, und null, eine oder mehrere Wasserflaschenhalter und genau einen Sattel, könnte dies ausgedrückt werden als: Bicycle_Accessories = Sattel [Bell | Horn] {water_bottle_holders} Diese Grammatik definiert die folgenden Möglichkeiten: saddlesaddle bellsaddle horn Sattel water_bottle_holder Sattelglocke water_bottle_holder Sattelglocke water_bottle_holder water_bottle_holder Usw.

X++-Grammatik

In diesem Artikel wird die formale Grammatik der X++-Sprache veranschaulicht.

So interpretieren Sie die formale BNF-Grammatik

In diesem Abschnitt wird die Grammatik von X++ in Backus Naur Form (BNF) beschrieben. Hier wird ein kleines Beispiel für BNF beschrieben.

AA ::= BB  CC_SYM
BB ::= JJ_SYM
   ::= KK_SYM

AA ist der Name einer Produktionsregel. Ein AA erfordert eine BBCC_SYM gefolgt von einer CC_SYM. A BB ist auch eine Produktionsregel. BB Daher ist es kein Terminal. BB muss entweder ein JJ_SYM oder ein KK_SYM sein. Sowohl JJ_SYM als auch KK_SYM sind Terminals, da sie nicht die Namen anderer Produktionsregeln sind. CC_SYM ist auch ein Terminal.

In der BNF für X++-Grammatik haben die meisten Terminals _SYM als Suffix ihres Namens.

Formale X++-Grammatik in BNF

Dieser Abschnitt enthält den BNF, der die Grammatik von X++ definiert.

    CMPL_UNIT ::= RETTYPEID  FUNC_HDR  FUNC_HEAD  BODY
              ::= RETTYPEID  DATA_HDR  CLASS_DECL
              ::= EXPR_HDR  IF_EXPR  SEMIOPT
              ::= RETTYPEID  FUNC_HDR  EVENT_DECL  BODY
    SEMIOPT ::= SEMICOLON_SYM
            ::= 
    CLASS_DECL ::= CLASS_HEADER  LEFTBR_SYM  DCL_EVENTMAP  DCL_LIST  RIGHTBR_SYM
    CLASS_HEADER ::= ATTRIBUTE_DEF  CLASS_MODIFIERS  CLASSORINTERFACE  STD_ID  EXTENDS  IMPLEMENTS
    ATTRIBUTE_DEF ::= LEFT_BRKT_SYM  ATTRIBUTE_INIT  ATTRIBUTE_LIST  RETTYPEID  RGHT_BRKT_SYM
                  ::= 
    ATTRIBUTE_INIT ::= 
                   .
    ATTRIBUTE_LIST ::= ATTRIBUTE
                   ::= ATTRIBUTE_LIST  LIST_SEP_SYM  ATTRIBUTE
    ATTRIBUTE ::= STD_ID
              ::= ATTRIBUTE_WITH_ARGS_BEGINS  ATTRIBUTE_WITH_ARGS_ENDS
    ATTRIBUTE_WITH_ARGS_BEGINS ::= STD_ID  LEFT_PAR_SYM
    ATTRIBUTE_WITH_ARGS_ENDS ::= ATTRIBUTE_ARGS  RGHT_PAR_SYM
    ATTRIBUTE_ARGS ::= ATTRIBUTE_CONSTANT
                   ::= ATTRIBUTE_ARGS  LIST_SEP_SYM  ATTRIBUTE_CONSTANT
    ATTRIBUTE_CONSTANT ::= INT_SYM
                       ::= DBL_SYM
                       ::= STR_SYM
                       ::= DATE_SYM
                       ::= DATETIME_SYM
                       ::= STD_ID  DBLCOLON_SYM  STD_ID
                       ::= TRUE_SYM
                       ::= FALSE_SYM
                       ::= INT64_SYM
                       ::= ATTRIBUTE_INTRINSIC
    ATTRIBUTE_INTRINSIC ::= INTRI_ID  LEFT_PAR_SYM  IARGS  RGHT_PAR_SYM
    CLASSORINTERFACE ::= CLASS_SYM
                     ::= INTERFACE_SYM
    CLASS_MODIFIERS ::= CLASS_MODS
                    ::= 
    CLASS_MODS ::= CLASS_MODIFIER
               ::= CLASS_MODS  RETTYPEID  CLASS_MODIFIER
    CLASS_MODIFIER ::= PUBLIC_SYM
                   ::= FINAL_SYM
                   ::= STATIC_SYM
                   ::= ABSTRACT_SYM
                   ::= PRIVATE_SYM
    EXTENDS ::= EXTENDS_SYM  STD_ID
            ::= 
    IMPLEMENTS ::= IMPLEMENTS_SYM  IMPLEMENTLIST
               ::= 
    IMPLEMENTLIST ::= STD_ID
                  ::= IMPLEMENTLIST  LIST_SEP_SYM  STD_ID
    DCL_EVENTMAP ::= 
    EVENT_DECL ::= ATTRIBUTE_DEF  EVENT_HEADER  PARM_DCL_LIST
    EVENT_HEADER ::= EVENT_MODIFIER  VOID_TYPE_SYM  STD_ID
    EVENT_MODIFIER ::= EVENT_SYM
    FUNC_HEAD ::= ATTRIBUTE_DEF  FUNCNAME  PARM_DCL_LIST
    FUNCNAME ::= FUNCTYPE  STD_ID
    FUNCTYPE ::= FUNC_MODIFIERS  DECL_TYPE
    FUNC_MODIFIERS ::= FUNC_MODS
                   ::= 
    FUNC_MODS ::= RETTYPEID  FUNC_MODIFIER
              ::= FUNC_MODS  RETTYPEID  FUNC_MODIFIER
    FUNC_MODIFIER ::= PUBLIC_SYM
                  ::= PRIVATE_SYM
                  ::= PROTECTED_SYM
                  ::= FINAL_SYM
                  ::= STATIC_SYM
                  ::= ABSTRACT_SYM
                  ::= DISPLAY_SYM
                  ::= EDIT_SYM
                  ::= SERVER_SYM
                  ::= CLIENT_SYM
    BODY ::= LEFTBR_SYM  DCL_FUNC_LIST  SEMIOPT  SECAUTHZCHECK  STMTLIST  SECAUTHZEND  RIGHTBR_SYM
    SECAUTHZCHECK ::= 
    SECAUTHZEND ::= 
    RETTYPEID ::= 
    FUNCTION_DEF ::= FUNC_HEADER  PARM_DCL_LIST  LOCAL_BODY
    FUNC_HEADER ::= DECL_TYPE  STD_ID
    PARM_DCL_LIST ::= RETTYPEID  PARM_START  PARM_LIST_OPT  RGHT_PAR_SYM  RETTYPEID
    PARM_START ::= LEFT_PAR_SYM
    PARM_LIST_OPT ::= PARM_LIST
                  ::= 
    PARM_LIST ::= DCL_INIT
              ::= PARM_LIST  LIST_SEP_SYM  DCL_INIT
    LOCAL_BODY ::= LEFTBR_SYM  DCL_LIST  SEMIOPT  STMTLIST  RETTYPEID  RIGHTBR_SYM
    DCL_LIST ::= DCL_LIST2
             ::= 
    DCL_LIST2 ::= DCL_STMT
              ::= DCL_LIST2  DCL_STMT
    DCL_FUNC_LIST ::= DCL_FUNC_LIST2
                  ::= 
    DCL_FUNC_LIST2 ::= DCL_STMT
                   ::= FUNCTION_DEF
                   ::= DCL_FUNC_LIST2  DCL_STMT
                   ::= DCL_FUNC_LIST2  FUNCTION_DEF
    DCL_STMT ::= DCL_INIT_LIST  RETTYPEID  SEMICOLON_SYM
    DCL_INIT_LIST ::= DCL_INIT
                  ::= DCL_CLIST  ASG_CLAUSE
    DCL_CLIST ::= DCL_INIT_LIST  LIST_SEP_SYM  STD_ID  ARR_DCL_IDX
    DCL_INIT ::= DECL  ASG_CLAUSE
    DECL ::= DECL_TYPE  STD_ID  ARR_DCL_IDX
    DECL_TYPE ::= STR_TYPE_SYM  STR_LEN
              ::= INT_TYPE_SYM
              ::= DBL_TYPE_SYM
              ::= DATE_TYPE_SYM
              ::= DATETIME_TYPE_SYM
              ::= TYPE_ID
              ::= QUEUE_TYPE_SYM
              ::= VOID_TYPE_SYM
              ::= ANY_TYPE_SYM
              ::= GUID_TYPE_SYM
              ::= INT64_TYPE_SYM
              ::= CLR_TYPE
    CLR_TYPE ::= CLR_NAMESPACE  TYPE_ID  CLR_ARRAY_TYPE_EXT
             ::= CLR_NAMESPACE  CLR_TYPE
    CLR_NAMESPACE ::= TYPE_ID  PERIOD_SYM
    CLR_ARRAY_TYPE_EXT ::= CLR_ARRAY_SPEC
                       ::= 
    CLR_ARRAY_SPEC ::= CLR_ARRAY_PART
                   ::= CLR_ARRAY_SPEC  CLR_ARRAY_PART
    CLR_ARRAY_PART ::= CLR_ARRAY_LEFT_PART  CLR_RECTANGULAR_LIST  RGHT_BRKT_SYM
    CLR_ARRAY_LEFT_PART ::= LEFT_BRKT_SYM
    CLR_RECTANGULAR_LIST ::= CLR_COMMA_LIST
                         ::= 
    CLR_COMMA_LIST ::= LIST_SEP_SYM
                   ::= CLR_COMMA_LIST  LIST_SEP_SYM
    STR_LEN ::= INT_SYM
            ::= 
    ARR_DCL_IDX ::= LEFT_BRKT_SYM  RANGE  ARRAY_MEM  RGHT_BRKT_SYM
                ::= 
    RANGE ::= IF_EXPR
          ::= 
    ARRAY_MEM ::= LIST_SEP_SYM  IF_EXPR
              ::= 
    ASG_CLAUSE ::= INIT_START  IF_EXPR
               ::= 
    INIT_START ::= ASG_SYM
    ASG_STMT ::= LVAL_FLD  ASSIGN  IF_EXPR
             ::= LVAL_LIST  ASG_SYM  IF_EXPR
             ::= LVAL_FLD  ASG_INC_DEC
             ::= ASG_INC_DEC  LVAL_FLD
             ::= LVAL_FLD  ASG_EVENT_HANDLER
    ASSIGN ::= ASG_SYM
           ::= ASGINC_SYM
           ::= ASGDEC_SYM
    ASG_INCDEC ::= ASGINC_SYM
               ::= ASGDEC_SYM
    ASG_EVENT_HANDLER ::= ASG_INCDEC  EVENTHANDLER_SYM  LEFT_PAR_SYM  QUALIFIER  STD_ID  RGHT_PAR_SYM
      ::= ASG_INCDEC  EVENTHANDLER_SYM  LEFT_PAR_SYM  STD_ID  DBLCOLON_SYM  STD_ID  RGHT_PAR_SYM
      ::= ASG_INCDEC  EVENTHANDLER_SYM  LEFT_PAR_SYM  QUALIFIER  EVAL_CLR_TYPE  DBLCOLON_SYM  STD_ID  RGHT_PAR_SYM
    ASG_INC_DEC ::= INC_SYM
                ::= DEC_SYM
    LVAL_FLD ::= FIELD
    LVAL_START ::= LEFT_BRKT_SYM
    LVAL_LIST ::= LVAL_START  LVALUES  RGHT_BRKT_SYM
    LVALUE ::= FIELD
    LVALUES ::= LVALUE
            ::= LVALUES  NEXTLVAL  LVALUE
    NEXTLVAL ::= LIST_SEP_SYM
    IF_EXPR ::= COND_TRUE  IF_EXPR
            ::= BOOL_EXPR
    COND_TRUE ::= COND_TEST  IF_EXPR  COLON_SYM
    COND_TEST ::= BOOL_EXPR  QUEST_SYM
    BOOL_EXPR ::= BOOL_EXPR  LOGOP  EXPR
              ::= EXPR
    LOGOP ::= AND_SYM
          ::= OR_SYM
    EXPR ::= SMPL_EXPR  RELOP  SMPL_EXPR
         ::= SMPL_EXPR  AS_SYM  STD_ID
         ::= SMPL_EXPR  IS_SYM  STD_ID
         ::= SMPL_EXPR  AS_SYM  EVAL_CLR_TYPE
         ::= SMPL_EXPR  IS_SYM  EVAL_CLR_TYPE
         ::= SMPL_EXPR
    RELOP ::= LT_SYM
          ::= LE_SYM
          ::= EQ_SYM
          ::= NE_SYM
          ::= GT_SYM
          ::= GE_SYM
          ::= LIKE_SYM
    SMPL_EXPR ::= SMPL_EXPR  ADDOP  TERM
              ::= TERM
    ADDOP ::= PLUS_SYM
          ::= MINUS_SYM
          ::= PHYSOR_SYM
    TERM ::= TERM  MULOP  CMPL_FACT
         ::= CMPL_FACT
    MULOP ::= MULT_SYM
          ::= DIV_SYM
          ::= MOD_SYM
          ::= INTDIV_SYM
          ::= SHIFTL_SYM
          ::= SHIFTR_SYM
          ::= PHYSAND_SYM
          ::= PHYSXOR_SYM
    CMPL_FACT ::= NOT_SYM  SGND_FACT
              ::= SGND_FACT
    SGND_FACT ::= SIGNOP  FACTOR
              ::= FACTOR
    SIGNOP ::= UMINUS_SYM
           ::= PHYSNOT_SYM
    FACTOR ::= LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM
           ::= CONSTANT
           ::= FIELD
           ::= DIRSEARCH
           ::= FUNCTION
           ::= INTRINSICS
           ::= EVAL
           ::= CONLITTERAL
           ::= NEW_CLR_ARRAY
    NEW_CLR_ARRAY ::= NEW_SYM  EVAL_CLR_TYPE  NEW_CLR_ARRAY_PART  LEFT_PAR_SYM  RGHT_PAR_SYM
    NEW_CLR_ARRAY_PART ::= CLR_SIZED_ARRAY  CLR_NOSIZED_ARRAY_SPEC
    CLR_SIZED_ARRAY ::= LEFT_BRKT_SYM  CLR_SMPL_EXPR_COMMA_LIST  RGHT_BRKT_SYM
    CLR_SMPL_EXPR_COMMA_LIST ::= SMPL_EXPR
      ::= CLR_SMPL_EXPR_COMMA_LIST  LIST_SEP_SYM  SMPL_EXPR
    CLR_NOSIZED_ARRAY_SPEC ::= CLR_NOSIZED_ARRAY_LIST
                           ::= 
    CLR_NOSIZED_ARRAY_LIST ::= CLR_NOSIZED_ARRAY
                           ::= CLR_NOSIZED_ARRAY_LIST  CLR_NOSIZED_ARRAY
    CLR_NOSIZED_ARRAY ::= LEFT_BRKT_SYM  CLR_EMPTY_COMMA_LIST  RGHT_BRKT_SYM
    CLR_EMPTY_COMMA_LIST ::= CLR_EMPTY_RECT_COMMA_LIST
                         ::= 
    CLR_EMPTY_RECT_COMMA_LIST ::= LIST_SEP_SYM
                              ::= CLR_EMPTY_RECT_COMMA_LIST  LIST_SEP_SYM
    CONLITTERAL ::= LEFT_BRKT_SYM  IF_EXPR  EXPR_LIST  RGHT_BRKT_SYM
    CONSTANT ::= INT_SYM
             ::= DBL_SYM
             ::= STR_SYM
             ::= DATE_SYM
             ::= DATETIME_SYM
             ::= STD_ID  DBLCOLON_SYM  STD_ID
             ::= TRUE_SYM
             ::= FALSE_SYM
             ::= NULL_SYM
             ::= INT64_SYM
             ::= QUALIFIER  EVAL_CLR_TYPE  DBLCOLON_SYM  STD_ID
             ::= QUALIFIER  STD_ID  DBLCOLON_SYM  STD_ID
    DIRSEARCH ::= DIRS_HEADER  PERIOD_SYM  STD_ID  ARR_IDX
              ::= DIRS_HEADER  PERIOD_SYM  FLD_NUM  ARR_IDX
    DIRS_HEADER ::= LEFT_PAR_SYM  SET_DIRS  FIND_JOIN  RGHT_PAR_SYM
    SET_DIRS ::= 
    FIELD ::= QUALIFIER  STD_ID  ARR_IDX
          ::= QUALIFIER  FLD_NUM  ARR_IDX
          ::= STD_ID  ARR_IDX
    QUALIFIER ::= EVAL  PERIOD_SYM
              ::= STD_ID  PERIOD_SYM
    FLD_NUM ::= LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM
    ARR_IDX ::= LEFT_BRKT_SYM  SMPL_EXPR  RGHT_BRKT_SYM
            ::= 
    EXPR_LIST ::= EXPR_LIST2
              ::= 
    EXPR_LIST2 ::= LIST_SEP_SYM  IF_EXPR
               ::= EXPR_LIST2  LIST_SEP_SYM  IF_EXPR
    FUNCTION ::= FUNC_ID  LEFT_PAR_SYM  EVAL_FUNCTION_NAME  PAR_LIST  RGHT_PAR_SYM
    EVAL_FUNCTION_NAME ::= 
    EVAL_NAME ::= EVAL_ID  LEFT_PAR_SYM
              ::= STD_ID  LEFT_PAR_SYM
              ::= STD_ID  DBLCOLON_SYM  STD_ID  LEFT_PAR_SYM
              ::= SUPER_SYM  LEFT_PAR_SYM
              ::= NEW_SYM  STD_ID  LEFT_PAR_SYM
              ::= NEW_SYM  EVAL_CLR_TYPE  LEFT_PAR_SYM
              ::= QUALIFIER  EVAL_CLR_TYPE  DBLCOLON_SYM  STD_ID  LEFT_PAR_SYM
              ::= QUALIFIER  STD_ID  LEFT_PAR_SYM
              ::= QUALIFIER  STD_ID  DBLCOLON_SYM  STD_ID  LEFT_PAR_SYM
    EVAL_CLR_TYPE ::= NAMESPACE  STD_ID
                  ::= NAMESPACE  EVAL_CLR_TYPE
    NAMESPACE ::= STD_ID  PERIOD_SYM
    EVAL ::= EVAL_NAME  PAR_LIST  RGHT_PAR_SYM
    PAR_LIST ::= PRM_LIST
             ::= 
    PRM_LIST ::= PAR_ELEM
             ::= PRM_LIST  LIST_SEP_SYM  PAR_ELEM
    PAR_ELEM ::= IF_EXPR
             ::= BYREF_SYM  FIELD
    INTRINSICS ::= INTRI_ID  LEFT_PAR_SYM  IARGS  RGHT_PAR_SYM
    IARGS ::= STD_ID
          ::= STR_SYM
          ::= STD_ID  LIST_SEP_SYM  STD_ID
          ::= 
    STMTLIST ::= STATEMENTS
             ::= 
    STATEMENTS ::= STATEMENT
               ::= STATEMENTS  STATEMENT
    STATEMENT ::= COMPOUND_STMT
              ::= WHILE_STMT
              ::= FOR_STMT
              ::= DO_STMT
              ::= SEARCH_STMT
              ::= FIND_STMT
              ::= PRINT_STMT
              ::= WINDOW_STMT
              ::= IF_STMT
              ::= SWITCH_STMT
              ::= EXPR_STMT
              ::= PAUSE_STMT
              ::= BP_CLAUSE
              ::= BREAK_STMT
              ::= CONTINUE_STMT
              ::= RETURN_CLAUSE
              ::= MOVE_REC_STMT
              ::= THROW_STMT
              ::= TRY_STMT
              ::= RETRY_STMT
              ::= TTS_STMT
              ::= FLUSH_STMT
              ::= TBLLOCK_STMT
              ::= CHANGE_STMT
              ::= UPDATE_STMT
              ::= INSERT_STMT
              ::= UNCHECKED_STMT
    COMPOUND_STMT ::= LEFTBR_SYM  STMTLIST  RIGHTBR_SYM
    THROW_STMT ::= THROW_SYM  IF_EXPR  SEMICOLON_SYM
    TRY_STMT ::= TRY_BLOCK  CATCH_LIST
    TRY_BLOCK ::= TRY_START  STATEMENT
    TRY_START ::= TRY_SYM
    CATCH_LIST ::= CATCH_STMT
               ::= CATCH_LIST  CATCH_STMT
    CATCH_STMT ::= CATCH_EXPR  PRE_CATCH  STATEMENT  POST_CATCH
    CATCH_EXPR ::= CATCH_SYM  LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM
      ::= CATCH_SYM  LEFT_PAR_SYM  IF_EXPR  LIST_SEP_SYM  TABLEINSTANCE  RGHT_PAR_SYM
      ::= CATCH_SYM
    PRE_CATCH ::= 
    POST_CATCH ::= 
    TABLEINSTANCE ::= INSTANCENAME
    INSTANCENAME ::= QUALIFIER  STD_ID  ARR_IDX
                 ::= STD_ID  ARR_IDX
    RETRY_STMT ::= RETRY_SYM  SEMICOLON_SYM
    WHILE_STMT ::= WHILE_TEST  STATEMENT
    WHILE_TEST ::= WHILE  LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM
    WHILE ::= WHILE_SYM
    DO_STMT ::= DO_BODY  DO_TEST  SEMICOLON_SYM
    DO_BODY ::= DO_HEADER  STATEMENT
    DO_HEADER ::= DO_SYM
    DO_TEST ::= WHILE_SYM  LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM
    FOR_STMT ::= FOR_HEADER  STATEMENT
    FOR_HEADER ::= FOR_TEST  SEMICOLON_SYM  FOR_ASG  RGHT_PAR_SYM
    FOR_TEST ::= FOR_INIT  SEMICOLON_SYM  IF_EXPR
    FOR_INIT ::= FOR_SYM  LEFT_PAR_SYM  FOR_ASG
    FOR_ASG ::= LVAL_FLD  ASSIGN  IF_EXPR
            ::= LVAL_FLD  ASG_INC_DEC
            ::= ASG_INC_DEC  LVAL_FLD
    JOIN_LIST ::= JOIN_SPECS
              ::= 
    JOIN_SPECS ::= JOIN_SPEC
               ::= JOIN_SPECS  JOIN_SPEC
    JOIN_SPEC ::= JOIN_ORDER  WHERE  IF_EXPR
              ::= JOIN_ORDER
    JOIN_ORDER ::= JOIN_USING
               ::= JOIN_USING  ORDER_GROUP
    JOIN_USING ::= JOIN_CLAUSE  USING_INDEX  STD_ID
               ::= JOIN_CLAUSE  USING_INDEX  HINT_SYM  STD_ID
               ::= JOIN_CLAUSE
    JOIN_CLAUSE ::= OUTER  JOIN_SYM  SELECTOPT  TABLE
    OUTER ::= OUTER_SYM
          ::= EXISTS_SYM
          ::= NOTEXISTS_SYM
          ::= 
    SEARCH_STMT ::= SEARCH_JOIN  STATEMENT
    SEARCH_JOIN ::= SEARCH_WHERE  JOIN_LIST
    SEARCH_WHERE ::= SEARCH_ORDER  WHERE  IF_EXPR
                 ::= SEARCH_ORDER
    WHERE ::= WHERE_SYM
    SUM_ELEM ::= SUM_FUNC  LEFT_PAR_SYM  STD_ID  RGHT_PAR_SYM
    SUM_FUNC ::= SUM_SYM
             ::= AVG_SYM
             ::= CNT_SYM
             ::= MINOF_SYM
             ::= MAXOF_SYM
    SEARCH_ORDER ::= SEARCH_USING
                 ::= SEARCH_USING  ORDER_GROUP
    ORDER_GROUP ::= ORDERBY_CLAUSE  OPT_GROUPBY
                ::= GROUPBY_CLAUSE  OPT_ORDERBY
    OPT_GROUPBY ::= GROUPBY_CLAUSE
                ::= 
    OPT_ORDERBY ::= ORDERBY_CLAUSE
                ::= 
    ORDERBY_CLAUSE ::= ORDER_SYM  OPT_BY  ORDER_ELEM
                   ::= ORDERBY_CLAUSE  LIST_SEP_SYM  ORDER_ELEM
    GROUPBY_CLAUSE ::= GROUP_SYM  OPT_BY  ORDER_ELEM
                   ::= GROUPBY_CLAUSE  LIST_SEP_SYM  ORDER_ELEM
    ORDER_ELEM ::= STD_ID  INDEX  DIRECTION
               ::= ORDER_QUALIFIER  STD_ID  INDEX  DIRECTION
    ORDER_QUALIFIER ::= STD_ID  PERIOD_SYM
    INDEX ::= LEFT_BRKT_SYM  INT_SYM  RGHT_BRKT_SYM
          ::= 
    DIRECTION ::= ASCEND_SYM
              ::= DESCEND_SYM
              ::= 
    OPT_BY ::= BY_SYM
           ::= 
    SEARCH_USING ::= SEARCH_CLAUSE  USING_INDEX  STD_ID
                 ::= SEARCH_CLAUSE  USING_INDEX  HINT_SYM  STD_ID
                 ::= SEARCH_CLAUSE
    USING_INDEX ::= INDEX_SYM
    SEARCH_CLAUSE ::= WHILE_SYM  SELECT_SYM  SELECTOPT  CROSSCOMPANY_CLAUSE  VALIDTIMESTATE_CLAUSE  TABLE
    CROSSCOMPANY_CLAUSE ::= CROSSCOMPANY_SYM
                        ::= CROSSCOMPANY_SYM  COLON_SYM  STD_ID
                        ::= 
    VALIDTIMESTATE_CLAUSE ::= VALIDTIMESTATE_SYM  LEFT_PAR_SYM  STD_ID  LIST_SEP_SYM  STD_ID  RGHT_PAR_SYM
      ::= VALIDTIMESTATE_SYM  LEFT_PAR_SYM  STD_ID  RGHT_PAR_SYM
      ::= 
    SELECTOPT ::= 
              ::= SELECTOPT  REVERSE_SYM
              ::= SELECTOPT  FIRSTFAST_SYM
              ::= SELECTOPT  FIRSTONLY_SYM
              ::= SELECTOPT  FIRSTONLY_SYM1
              ::= SELECTOPT  FIRSTONLY_SYM10
              ::= SELECTOPT  FIRSTONLY_SYM100
              ::= SELECTOPT  FIRSTONLY_SYM1000
              ::= SELECTOPT  FORUPDATE_SYM
              ::= SELECTOPT  NOFETCH_SYM
              ::= SELECTOPT  FORCE_SELECT_ORDER_SYM
              ::= SELECTOPT  FORCE_NESTED_LOOP_SYM
              ::= SELECTOPT  FORCE_LITERALS_SYM
              ::= SELECTOPT  FORCE_PLACEHOLDERS_SYM
              ::= SELECTOPT  REPEATABLEREAD_SYM
              ::= SELECTOPT  OPTIMISTICLOCK_SYM
              ::= SELECTOPT  PESSIMISTICLOCK_SYM
              ::= SELECTOPT  GENERATEONLY_SYM
    FIND_STMT ::= FIND_JOIN  SEMICOLON_SYM
    FIND_JOIN ::= FIND_WHERE  JOIN_LIST
    FIND_WHERE ::= FIND_ORDER  WHERE  IF_EXPR
               ::= FIND_ORDER
    FIND_ORDER ::= FIND_USING
               ::= FIND_USING  ORDER_GROUP
    FIND_USING ::= FIND_TABLE  USING_INDEX  STD_ID
               ::= FIND_TABLE  USING_INDEX  HINT_SYM  STD_ID
               ::= FIND_TABLE
    FIND_TABLE ::= SELECT_SYM  SELECTOPT  CROSSCOMPANY_CLAUSE  VALIDTIMESTATE_CLAUSE  TABLE
      ::= DELETE_SYM  SELECTOPT  CROSSCOMPANY_CLAUSE  VALIDTIMESTATE_CLAUSE  TABLE
    TABLE ::= FLD_LIST  OPT_FROM
    FLD_LIST ::= MULT_SYM
             ::= FIELD_LIST
    FIELD_LIST ::= FIELD_SPEC
               ::= FIELD_LIST  LIST_SEP_SYM  FIELD_SPEC
    FIELD_SPEC ::= STD_ID  INDEX
               ::= SUM_ELEM
    OPT_FROM ::= FROM_SYM  STD_ID
             ::= 
    SETFIELDSMODE ::= 
    UPDATE_STMT ::= UPDATETABLE  SET_SYM  SETFIELDSMODE  FIELDASSIGNMENTS  OPT_WHERE  JOIN_LIST  SEMICOLON_SYM
    UPDATETABLE ::= UPDATE_SYM  SELECTOPT  CROSSCOMPANY_CLAUSE  STD_ID
    OPT_WHERE ::= WHERE  IF_EXPR
              ::= 
    FIELDASSIGNMENTS ::= FIELDASSIGNMENTS  LIST_SEP_SYM  FIELDASSIGNMENT
                     ::= FIELDASSIGNMENT
    FIELDASSIGNMENT ::= STD_ID  INDEX  ASG_SYM  IF_EXPR
    INSERT_PART ::= INSERT_SYM  CROSSCOMPANY_CLAUSE  INSERT_NAME  LEFT_PAR_SYM  INSERTFIELDLIST  RGHT_PAR_SYM
    INSERT_NAME ::= STD_ID
    INSERT_STMT ::= INSERT_PART  FIND_JOIN  SEMICOLON_SYM
    INSERTFIELDLIST ::= INSERTFIELD
                    ::= INSERTFIELDLIST  LIST_SEP_SYM  INSERTFIELD
    INSERTFIELD ::= STD_ID  INDEX
    PRINT_STMT ::= PRINT_CLAUSE  AT_CLAUSE  SEMICOLON_SYM
    PRINT_CLAUSE ::= PRINT  IF_EXPR  EXPR_LIST
    PRINT ::= PRINT_SYM
    AT_CLAUSE ::= AT_SYM  IF_EXPR  LIST_SEP_SYM  IF_EXPR
              ::= 
    WINDOW_STMT ::= WINDOW_SYM  IF_EXPR  LIST_SEP_SYM  IF_EXPR  AT_CLAUSE  SEMICOLON_SYM
    IF_STMT ::= ELSE_STMT
            ::= IF_CONDS
    IF_CONDS ::= IF_COND  STATEMENT
    IF_COND ::= IF_SYM  LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM
    ELSE_STMT ::= ELSE  STATEMENT
    ELSE ::= IF_CONDS  ELSE_SYM
    SWITCH_STMT ::= CASE_LIST  RIGHTBR_SYM
    CASE_LIST ::= SWITCH_SYM  LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM  LEFTBR_SYM
              ::= CASE_TESTS  STMTLIST
    CASE_TESTS ::= CASE_HEADER  COLON_SYM
               ::= CASE_LIST  DEFAULT_SYM  COLON_SYM
    CASE_HEADER ::= CASE  IF_EXPR
                ::= CASEALT  IF_EXPR
    CASE ::= CASE_LIST  CASE_SYM
    CASEALT ::= CASE_HEADER  LIST_SEP_SYM
    EXPR_STMT ::= ASG_STMT  SEMICOLON_SYM
              ::= FUNCTION  SEMICOLON_SYM
              ::= INTRINSICS  SEMICOLON_SYM
              ::= EVAL  SEMICOLON_SYM
    PAUSE_STMT ::= PAUSE_SYM  SEMICOLON_SYM
    BP_CLAUSE ::= BP_SYM  SEMICOLON_SYM
    BREAK_STMT ::= BREAK_SYM  SEMICOLON_SYM
    CONTINUE_STMT ::= CONTINUE_SYM  SEMICOLON_SYM
    RETURN_CLAUSE ::= RETURN_SYM  SEMICOLON_SYM
                  ::= RETURN_SYM  IF_EXPR  SEMICOLON_SYM
    TTS_STMT ::= TTSABORT_SYM  SEMICOLON_SYM
             ::= TTSBEGIN_SYM  SEMICOLON_SYM
             ::= TTSEND_SYM  SEMICOLON_SYM
    FLUSH_STMT ::= FLUSH  ID_LIST  SEMICOLON_SYM
    FLUSH ::= FLUSH_SYM
    TBLLOCK_STMT ::= TABLELOCK  ID_LIST  SEMICOLON_SYM
    TABLELOCK ::= TABLELOCK_SYM
    ID_LIST ::= STD_ID
            ::= ID_LIST  LIST_SEP_SYM  STD_ID
    MOVE_REC_STMT ::= NEXT_SYM  TABLE  SEMICOLON_SYM
    CHANGE_STMT ::= CHANGE_HEADER  STATEMENT
    CHANGE_HEADER ::= CHANGE  LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM
    CHANGE ::= CHANGECOMP_SYM
           ::= CHANGESITE_SYM
    UNCHECKED_STMT ::= UNCHECKED_HEADER  STATEMENT
    UNCHECKED_HEADER ::= UNCHECKED_SYM  LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM

Weitere Ressourcen

X++-Sprachreferenz