Delen via


X++-syntaxis

Opmerking

Community-belangengroepen zijn nu verplaatst van Yammer naar Microsoft Viva Engage. Als u wilt deelnemen aan een Viva Engage-community en deel wilt nemen aan de meest recente discussies, vult u het formulier Toegang aanvragen tot Finance and Operations Viva Engage Community in en kiest u de community waaraan u wilt deelnemen.

Dit artikel bevat de syntaxisreferentie voor X++.

X++ trefwoorden

De X++-trefwoorden die in de volgende tabel worden weergegeven, zijn gereserveerd. Deze trefwoorden kunnen niet worden gebruikt voor andere doeleinden.

Gereserveerd woord Description Verwante informatie
! Niet. Relationele operators
!= Ongelijkheidsoperator (niet gelijk aan). Relationele operators
# Voorvoegsel voor macronamen. Procedure: #define en #if gebruiken om een macro te testen
& Binair EN. Rekenkundige operatoren
&& Logische AND. Relationele operators
( Operator voor functieaanroep, die het begin van de functieaanroep aangeeft.
) Operator voor functieoproep, die het einde van de functie-aanroep aangeeft.
* Vermenigvuldigen. Het sterretje (*) wordt ook gebruikt in X++ SQL. Eén gebruik is het ondertekenen van alle velden uit de tabellen in een select instructie. Een ander gebruik is als jokerteken met de like operator, om 0 tot vele tekens van elk soort te ondertekenen. De like operator gebruikt ook het teken ? . Rekenkundige operatoren
^ Binair XOR. Rekenkundige operatoren
| Binair OF. Rekenkundige operatoren
|| Logische OR. Relationele operators
~ Niet. Rekenkundige operatoren
+ Plus. Rekenkundige operatoren
++ Vermeerdering. Toewijzingsoperatoren
+= Additieve toewijzing. Toewijzingsoperatoren
, Komma-operator. Expressies gescheiden door komma's worden opeenvolgend van links naar rechts geëvalueerd.
- Minus. Rekenkundige operatoren
-- De operator voor verlagen. Toewijzingsoperatoren
-= Subtractive toewijzing. Toewijzingsoperatoren
. De toegangsoperator voor klasseleden krijgt bijvoorbeeld formRun.run toegang tot de run methode van een object van het klassetype FormRun.
/ Verdelen. Rekenkundige operatoren
\ Escape in tekenreeksen. Escapes extra aanhalingstekens en bepaalde letters zoals '\t' voor tab.
@ Escape van trefwoorden. Kan bijvoorbeeld var @str = 1@abstract; niet compileren zonder het @ teken dat ervoor zorgt dat een tekenreeks die deze volgt als een id wordt beschouwd. Het is ook van invloed op letterlijke tekenreeksen, door het effect van het \escape-teken te negeren en door de tekenreeks in te schakelen voor meer dan één regel in de broncode. De nieuwe regel wordt vertegenwoordigd door één teken van hexadecimale 0x0A, dat meestal een regelfeed wordt genoemd. Geen regelterugloopteken van hexadecimale 0x0D is opgenomen, zoals in 0x0D0A.
: Het dubbele punt (:) wordt gebruikt om hoofdletterwaarden in de switch instructie te scheiden.
:: Wordt gebruikt om statische (klasse)-methoden aan te roepen: ClassName::methodName() en om letterlijke opsommingen aan te wijzen, zoals NoYes::Yes.
; Beëindigt instructies. Wordt gebruikt in for lussen of als scheidingsteken voor initialisatie-, update- en waardecontroleonderdelen.
< Kleiner dan. Relationele operators
<< Linkerdienst. Rekenkundige operatoren
<= Kleiner dan of gelijk aan. Rekenkundige operatoren
= Toewijzingsoperator. Het argument links van '=' is ingesteld op de waarde van het argument rechts. Toewijzingsoperatoren
== Retourneert waar als de expressies gelijk zijn. Relationele operators
> Groter dan. Relationele operators
>= Groter dan of gelijk aan. Relationele operators
>> Met bitsgewijze shift naar rechts. Deze operator verschuift bits aan de linkerkant door de hoeveelheid aan de rechterkant. Elke verschuiving verdeelt het getal door 2^n, waarbij n het aantal verplaatste posities is. Rekenkundige operatoren
?: Ternaire operator. Het vraagteken (?) wordt ook door de like operator gebruikt om precies één teken van welk type dan ook te beschrijven. De like operator gebruikt ook het teken. Ternary Operator (?)
[ Matrixdeclaratie, open. Moet worden gebruikt met ']'.
] Matrixdeclaratie, sluiten. Moet worden gebruikt met [.
{ Hiermee start u een samengestelde instructie die op zijn beurt nul of meer instructies kan bevatten. De samengestelde instructie eindigt met de dichtstbijzijnde overeenkomende "}".
} Geeft het einde van de samengestelde instructie aan die hierboven wordt beschreven. Er moet een {worden weergegeven vóór de eerste van deze instructies.
abstract Klasse- en methodeaanpassing. Een abstracte klasse kan niet worden samengesteld met het nieuwe trefwoord. Alleen de klassen die ermee zijn afgeleid, kunnen. Een abstracte methode kan niet worden aangeroepen, alleen methoden die deze kunnen overschrijven. Een tabel kan worden gewijzigd als abstract door de eigenschap Abstract in te stellen op Ja in de AOT of door de DictTable klasse te gebruiken. De eigenschap Abstract is standaard ingesteld op Nee en kan alleen worden ingesteld als de tabel wordt uitgebreid door een andere tabel. Elke rij in een abstracte tabel moet een afhankelijke rij in een afgeleide tabel hebben. Dit betekent dat elke rij in een abstracte tabel een waarde heeft die groter is dan nul in het eigenschapsveld InstanceRelationType . Er zijn geen andere effecten van het markeren van een tabel als abstract. Informeel gebruiken programmeurs vaak de term concreet om een klasse te beschrijven die niet-abstract is. Overzicht van tabelovername van methodemodifiers
anytype Een type dat waarden van elk type kan bevatten. Anytype
als Nodig wanneer u een basisklassevariabele toewijst aan een afgeleide klassevariabele. Op basis van een klasse die een Derived klasse Base, voorkomt de instructie myDerived = myBase as Derived; bijvoorbeeld een compilerfout door het als trefwoord te gebruiken. Dit trefwoord is ook van toepassing wanneer u een basistabelvariabele toewijst aan een afgeleide tabelvariabele. Als de waarde (myBase) niet van het aangewezen type (afgeleid) is, retourneert de expressie null. Expressieoperators: Is and As for Overname
Asc Een optie voor de orderby of groupby component in een select instructie. De sortering is oplopend. Syntaxis van instructie selecteren
at Hiermee geeft u de positie van een afdrukvenster op als onderdeel van een print instructie. De afdrukinstructie mag niet worden gebruikt. Afdrukinstructies
Avg Retourneert het gemiddelde van de velden uit de rijen die zijn opgegeven door de group by component in een select instructie. Syntaxis van instructie selecteren
break Onmiddellijk afsluiten van een iteratief codeblok. Onderbrekingsinstructies
Onderbrekingspunt Vertegenwoordigt een onderbrekingspunt dat is ingesteld voor foutopsporingsdoeleinden. Als u een onderbrekingspunt in uw code wilt instellen, schrijft u: breakpoint;
bij Onderdeel van een gereserveerde termijn, zoals groeperen op en bestellen op.
byref Hiermee geeft u op dat de parameter die wordt doorgegeven aan de aangeroepen methode, wordt doorgegeven door verwijzing (adres), in plaats van op waarde. Byref wordt gebruikt in X++ bij het aanroepen van een .NET-methode die een parameter op basis van verwijzing gebruikt (zoals met de C#-trefwoorden ofverw). Procedure: Gebruik het byref-trefwoord voor CLR Interop.
geval Selectie binnen een switch instructie. Switch-instructies
vangen Wordt gebruikt bij het afhandelen van uitzonderingen. Afhandeling van uitzonderingen met een poging en trefwoorden vangen
changeCompany Hiermee wijzigt u de database-instellingen in een ander bedrijf. Bedrijfsontwerppatroon wijzigen
klasse Declareert een klasse. Klassen in X++
cliënt Methodeaanpassing. Deze modifiers worden niet meer gebruikt. Alle methoden worden uitgevoerd op de serverlaag. Methodeaanpassingen
container Geeft het container type aan. Containers bevatten een reeks atomische waarden en andere containers. Containers
continue Dwingt de volgende iteratie van een lus af. Continue instructies
aantal Retourneert het aantal records uit de rijen die zijn opgegeven door de group by component in een select instructie. Syntaxis van instructie selecteren
crossCompany Zorgt ervoor dat een select instructie gegevens retourneert voor alle bedrijven waaruit de gebruiker gemachtigd is om te lezen. Basisbeginselen van X++-code voor meerdere bedrijven
date Hiermee geeft u een variabele van het type date. Datums
standaard Standaardcase binnen switch instructies. Het codeblok in het standaardonderdeel wordt uitgevoerd als de switchwaarde niet overeenkomt met een van de case componenten in de switch instructie. Switch-instructies
delegate Een klasselid dat meerdere verwijzingen naar methoden in andere klassen kan opslaan en om al deze methoden aan te roepen wanneer u hierom wordt gevraagd. Een gemachtigde kan verwijzingen naar verschillende soorten methoden opslaan, waaronder de volgende:
  • statische methoden in X++-klassen
  • exemplaarmethoden in X++-klassen
  • methoden voor .NET Framework-klassen
Gebeurtenisterminologie en trefwoorden X++, C#-vergelijking: gebeurtenis
delete_from Hiermee kunt u records uit de database verwijderen. delete_from
Desc Een optie voor de order by of group by component in een select instructie. De sortering is aflopend. Syntaxis van instructie selecteren
beeldscherm Methodeaanpassing. Er wordt een weergave<-/weergavemethode> gebruikt om berekende waarden in een formulierbesturingselement weer te geven. In tegenstelling tot normale velden worden deze waarden niet opgeslagen in de database, maar dynamisch berekend. Methodeaanpassingen
div Deling van gehele getallen. Rekenkundige operatoren
doen Begin van een do...while lus. Doen... while Lussen
edit Methodeaanpassing. Met een edit methode in X++ kunnen gebruikers waarden in een formulierbesturingselement wijzigen tijdens het uitvoeren van aangepaste logica. In tegenstelling tot display methoden, waarmee alleen berekende waarden worden weergegeven, kunnen bewerkingsmethoden zowel weergeven als bewerken. Methodeaanpassingen
anders Voorwaardelijke uitvoering (if...else). Het else deel van de if instructie wordt uitgevoerd als de expressie in de if-instructie wordt geëvalueerd false if en if ... else-instructies
eventHandler Moet worden gebruikt telkens wanneer u een methodereferentie toevoegt aan of verwijdert uit een gemachtigde met behulp van de += of -= operator. Bijvoorbeeld: myDelegate += eventHandler(OtherClass::myStaticMethod); Gebeurtenisterminologie en trefwoorden X++, C#-vergelijking: gebeurtenis
Bestaat Wordt gebruikt met join componenten in select instructies. Syntaxis van instructie selecteren
Breidt Een component voor klasse- of interfacedeclaratie. Als uw klas niet expliciet een andere klasse uitbreidt, wordt uw klasse beschouwd als uitbreiding van de Object klasse (alsof u 'object uitbreiden' hebt geschreven). Een subklasse maken
onwaar Booleaanse letterlijke waarde. Booleaans
finaal Klasse- en methodeaanpassing. Hiermee geeft u op dat deze methode niet kan worden overschreven. Methodeaanpassingen
firstFast Wordt gebruikt in select instructies om het ophalen voor de eerste rij te versnellen. Syntaxis van instructie selecteren
firstOnly Wordt gebruikt in select instructies om alleen de eerste record op te halen. Het firstOnly trefwoord garandeert niet dat maximaal één record wordt opgehaald door een X++ SQL-instructie select . Als de AOS de EntireTable cache kan gebruiken om te voldoen aan de gegevensvereisten van de select instructie, wordt het firstOnly trefwoord genegeerd. Syntaxis van instructie instellen op basis van cache selecteren
firstOnly10 Hetzelfde als firstOnly, behalve retourneert 10 rijen in plaats van één.
firstOnly100 Hetzelfde als firstOnly, met uitzondering van 100 rijen in plaats van één.
firstOnly1000 Hetzelfde als firstOnly, behalve retourneert 1000 rijen in plaats van één.
flush Hiermee wist u de hele tabelcache. Dit kan handig zijn als u ervoor wilt zorgen dat wijzigingen die in de tabel zijn aangebracht, onmiddellijk worden doorgevoerd in volgende bewerkingen. Opslaan in cache op basis van set
for Voor herhaling van lus. Voor lussen
forceLiterals Wordt gebruikt in select instructies om werkelijke waarden weer te geven die worden gebruikt in where componenten voor de Microsoft SQL Server-database op het moment van optimalisatie. Syntaxis van instructie selecteren
forceNestedLoop Dwingt de SQL Server-database om een geneste lus-algoritme te gebruiken om een bepaalde SQL-instructie met een join. Syntaxis van instructie selecteren
forcePlaceholders Wordt gebruikt in select instructies om de kernel te instrueren de werkelijke waarden die worden gebruikt in where componenten voor de Microsoft SQL Server-database op het moment van optimalisatie niet zichtbaar te maken. Syntaxis van instructie selecteren
forceSelectOrder Dwingt de SQL Server-database om toegang te krijgen tot de tabellen in een join in de opgegeven volgorde. Syntaxis van instructie selecteren
forUpdate Records exclusief selecteren voor update. De bewerking die moet worden uitgevoerd op de records die worden opgehaald, is een update. Afhankelijk van de onderliggende database kunnen de records worden vergrendeld voor andere gebruikers. Syntaxis van instructie selecteren
van Een deel van een select verklaring. Met from de component wordt de tabelbuffer opgegeven waarin de kolommen bestaan. Syntaxis van instructie selecteren
group Onderdeel van de group by component in een select instructie. Syntaxis van instructie selecteren
if Voorwaardelijke uitvoering. if en if ... else-instructies
Implementeert Implementatie van een interface. Overzicht van interfaces
insert_recordset Kopieert gegevens uit een of meer tabellen naar één resulterende doeltabel op één servertrip. insert_recordset
int Hiermee geeft u een variabele van het type integer (32-bits). Gehele getallen
int64 Hiermee geeft u een variabele van het type integer (64-bits). Gehele getallen
interface Interfacedeclaratie. Overzicht van interfaces
is Hiermee wordt gevraagd of het object waarnaar wordt verwezen door een klassevariabele, wordt overgenomen van de opgegeven klasse of van de opgegeven klasse. Als een klasse bijvoorbeeld een Derived klasse Base, retourneert de expressie (myDerived is Base)waar. Dit trefwoord is van toepassing op overname van klassen en tabelovername. Expressieoperators: Is and As for Overname
join Tabellen worden samengevoegd op kolommen die gebruikelijk zijn voor beide tabellen. U kunt één resultatenset genereren op basis van meerdere tabellen met behulp van joins. Syntaxis van instructie selecteren
als Test op overeenkomsten op patroon, met jokertekens '*' en '?'. Relationele operators
maxof Retourneert het maximum van de velden uit de rijen die zijn opgegeven door de group by component. Syntaxis van instructie selecteren
minof Retourneert het minimum van de velden uit de rijen die zijn opgegeven door de group by component. Syntaxis van instructie selecteren
mod Retourneert het gehele getal van de linkerexpressie1 gedeeld door de rechterexpressie2. Informeel wordt dit ook wel de modulo-operator genoemd. (12 mod 7) == 5 is waar.
Nieuw Bediener. Hiermee maakt u een exemplaar van een klasse of wijst u geheugen toe voor een matrix.
next Haalt de volgende record op in een tabel of roept de volgende methode aan in een reeks opdrachten.
noFetch Geeft aan dat er nu geen records moeten worden opgehaald. Syntaxis van instructie selecteren
notExists Wordt gebruikt met join componenten in select instructies. Syntaxis van instructie selecteren
nul Symbolische constante.
optimistischelock Hiermee dwingt u een instructie uit te voeren met optimistisch gelijktijdigheidsbeheer, zelfs als een andere waarde is ingesteld in de tabel. Syntaxis van instructie selecteren
bevelen Onderdeel van de order by component in een select instructie. Syntaxis van instructie selecteren
buiten outer join. Syntaxis van instructie selecteren
pause Hiermee wordt de uitvoering van een taak gestopt. De gebruiker wordt gevraagd of de uitvoering moet worden voortgezet. Gebruik deze instructie niet in productiecode. Instructies selecteren
pessimisticLock Hiermee dwingt u een instructie uit te voeren met pessimistisch gelijktijdigheidsbeheer, zelfs als een andere waarde is ingesteld in de tabel. Syntaxis van instructie selecteren
print Hiermee kunt u uitvoer op het scherm weergeven. Gebruik deze instructie niet in productiecode. Afdrukinstructies
privé Wijzigingsmethode voor toegang. De methode kan alleen worden gebruikt binnen de klasse die de methode declareert. Toegangsbeheer voor methoden
Beschermd Wijzigingsmethode voor toegang. De methode kan worden gebruikt op basis van methoden in de klasse die de methoden declareren en in eventuele afgeleide klassen. Toegangsbeheer voor methoden
public Wijzigingsmethode voor toegang. De methode kan worden aangeroepen vanuit elke klasse. Toegangsbeheer voor methoden
echte Hiermee wordt het real type aangeduid, een decimaal type zonder afrondingsfouten. Reals
repeatableRead Hiermee geeft u op dat er geen andere transacties gegevens kunnen wijzigen die door logica in de huidige transactie zijn gelezen, totdat de huidige transactie is voltooid. Een expliciete transactie wordt voltooid op ttsAbort of op de buitenste ttsCommit. Voor een zelfstandige select-instructie is de transactieduur de duur van de select-opdracht . De database dwingt echter soms het equivalent van repeatableRead af in afzonderlijke select-instructies , zelfs zonder dat dit trefwoord wordt weergegeven in uw X++-code (afhankelijk van hoe de database besluit de tabellen te scannen). Zie de documentatie voor het onderliggende relationele databaseproduct voor meer informatie.
Opnieuw Wordt gebruikt bij het afhandelen van uitzonderingen. Afhandeling van uitzonderingen met een poging en trefwoorden vangen
terugkeren Retourneert van een methode. Declaratie van methoden
reverse Records worden in omgekeerde volgorde geretourneerd. Syntaxis van instructie selecteren
selecteren De select component geeft aan welke kolommen of weergaven worden weergegeven in de resultatenset. Instructies selecteren
server Methodeaanpassing. Deze wijzigingsfunctie wordt genegeerd en mag niet worden gebruikt, omdat alle methoden aan de serverzijde worden uitgevoerd. Methodeaanpassingen
montuur Wordt gebruikt met de opdracht update_recordset . update_recordset
statische Statische methoden verwijzen mogelijk niet naar instantievariabelen (alleen naar statische variabelen); kan worden aangeroepen met behulp van de klassenaam in plaats van op een exemplaar van de klasse ("MyClass.aStaticProcedure"). Methodeaanpassingen
Str Geeft het string type aan. Tekenreeksen
som Retourneert de som van de velden uit de rijen die zijn opgegeven door de group by component in een select instructie. Syntaxis van instructie selecteren
super Roept de methode aan die is overschreven door de huidige methode. Tabelmethoden
schakelaar Switch-instructie. Switch-instructies
tableLock Verouderd; tableLock is niet meer beschikbaar.
dit Een verwijzing naar het huidige exemplaar van de klasse. Wordt gebruikt in X++-code in een instantiemethode van de klasse. Wordt gebruikt om te verwijzen naar methodeleden van de klasse.
werpen Wordt gebruikt bij het afhandelen van uitzonderingen. Afhandeling van uitzonderingen met een poging en trefwoorden vangen
waar Booleaanse letterlijke waarde. Booleaans
proberen Wordt gebruikt bij het afhandelen van uitzonderingen. Afhandeling van uitzonderingen met een poging en trefwoorden vangen
ttsAbort Alle wijzigingen in de huidige transactie terugdraaien (dat wil bijvoorbeeld negeren). Transactie-integriteit
ttsBegin Markeert het begin van een transactie. Transactie-integriteit
ttsCommit Markeert het einde van een transactie, waarbij de wijzigingen in de tabellen worden doorgevoerd. Transactie-integriteit
update_recordset Hiermee staat u het bewerken van rijensets binnen één bewerking toe. update_recordset
validTimeState Hiermee filtert u rijen die worden opgehaald uit een geldige tijdstatustabel door een X++ SQL-instructie select . Bijvoorbeeld: selecteer validTimeState(myDateEffective) * uit xMyTable; ... of... selecteer validTimeState(myDateFrom, myDateTo) * uit xMyTable; Effecten van geldige tijdstatustabellen voor lees- en schrijfbewerkingen
leegte Identificeert een methode die geen waarde retourneert. Declaratie van methoden
where Een deel van een select verklaring. De where component geeft aan welke voorwaarden moeten worden voldaan, dat wil weten de rijen die u wilt opnemen in het resultaat. Syntaxis van instructie selecteren
terwijl Iteratie-instructie. Voert herhaaldelijk een instructie uit zolang de testvoorwaarde waar is. Tijdens lussen tijdens het selecteren van instructies
venster Hiermee kunt u de grootte van het uitvoervenster wijzigen. Wordt gebruikt met afdruk<-/afdrukinstructies> die niet worden aanbevolen in productiecode. Afdrukinstructies

Syntaxis van expressies

Een expressie in X++ wordt op een wiskundige of logische manier gebruikt. Expressies zijn gebaseerd op de gegevenstypen van de taal; Dat wil gezegd, een expressie retourneert altijd een waarde van een bepaald type. Deze waarde kan worden gebruikt in berekeningen, toewijzingen, voorwaardelijke instructies, enzovoort.

EBNF-beschrijving van expressies in X++

Termijn   Definition
Expression = Simple-expression [RelationalOperator Simple-expression ]
RelationalOperator = =
Eenvoudige expressie = Simple-expression [ +
Termijn = Compfactor { Mult-operator CompFactor }
Mult-operator = *
CompFactor = [ ! ] [ -
Kenmerk = Literal
Enum = EnumName :: Letterlijk
Variable = Id [ [ Expressie ] ] [ . Expressie ]
FunctionCall = [ Expressie (.
If-expression = Uitdrukking? Expressie: Expressie

Semantische beperkingen zijn van toepassing op de voorgaande syntaxis. U kunt geen methode aanroepen met behulp van de operator :: Op dezelfde manier kunt u het trefwoord niet gebruiken zonder een actief object; Dat wil gezegd, als u zich niet binnen een instantiemethode bevindt, enzovoort.

Voorbeelden

Voorbeeld van expressie Description
1 Een letterlijk geheel getal.
Noyes::Nee Een opsommingsverwijzing.
A Een variabeleverwijzing.
Debiteur::Zoeken("1") Een statische methode-aanroep (retourneert een klantvariabele).
(A > 3 ? true : false) Een if-expressie die waar of onwaar retourneert.
(selecteer CustTable waarbij CustTable.Account == "100"). NameRef Een select-expression. Retourneert het veld nameref in de tabel Klant. Dit is een tekenreeks.
A >= B Een logische expressie. Retourneert waar of onwaar.
A + B Een rekenkundige expressie. Som A en B.
A + B / C Berekent B/C en voegt dit vervolgens toe aan A.
~A + dit. Value() Somt binair getal niet A en het resultaat van de methode-aanroepwaarde voor het object in het bereik (dit).
Schuldenaar::Zoeken("1"). NameRef Retourneert het veld NameRef van de gevonden klantrecord.
Schuldenaar::Zoeken("1"). Balance() Een methode-aanroep in Balance de klanttabel (Debiteur::Zoeken retourneert een klant). Retourneert het saldo van de klant met rekeningnummer 1.

EbNF-overzicht

Extended Backus Naur Form (EBNF) is een metalanguage en wordt in deze handleiding gebruikt om de taalsyntaxis te beschrijven. Een EBNF-definitie bestaat uit productieregels, niet-terminalen en terminals. De belangrijkste termen worden weergegeven in de volgende tabel.

Belangrijkste termen Example Description
Terminals Work_Team Een terminal is één teken of een tekenreeks die nooit verandert.
Niet-terminal Employee Een niet-terminal is een beschrijving van een deel van een geldige zin in de taal die is gedefinieerd door een productieregel of een tekstuele beschrijving. Een niet-terminalsymbool kan altijd worden uitgevouwen tot een of meer terminalsymbolen.
Productieregels Werknemer = Ontwikkelaar Tester

Example

Work_Team = Manager Werknemer {, Werknemer} Werknemer = Ontwikkelaar | Tester In dit voorbeeld wordt een Work_Team gedefinieerd als bestaande uit een Manager en een of meer Employees. Een Employee wordt gedefinieerd als een Developer, of een Tester. De symbolen die in het voorbeeld worden gebruikt, worden beschreven in de volgende tabel.

Speciale symbolen in EBNF

Symbol Description
(Expressie) Haakjes houden de symbolen (terminals en niet-terminalen) bij elkaar. Ze kunnen overal aan de rechterkant van een productieregel worden geplaatst.
Expressie1 Expressie2
[Expressie] Optioneel: de items tussen [ en ] zijn optioneel. Alle of geen van de items in de haken zijn opgenomen.
{Expression} Herhalen: de items tussen { en } zijn optioneel, maar kunnen zo vaak als nodig worden herhaald.

Als de accessoires die u voor uw fiets koopt bijvoorbeeld bestaan uit een zadel, waterfleshouders, klokken en hoorns, en u een klok of hoorn kunt hebben, en nul, een of meer waterfleshouders en precies één zadel, kan dit worden uitgedrukt als: Bicycle_Accessories = zadel [bel | hoorn] {water_bottle_holders} Deze grammatica definieert de volgende mogelijkheden: saddlesaddle bellsaddle horn zadel water_bottle_holder zadelbel water_bottle_holder zadelbel water_bottle_holder water_bottle_holder Enzovoort.

X++ Grammatica

In dit artikel wordt de formele grammatica van de X++-taal beschreven.

De formele BNF-grammatica interpreteren

In deze sectie wordt de grammatica van X++ in Backus Naur Form (BNF) beschreven. Hier wordt een klein voorbeeld van BNF beschreven.

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

AA is de naam van een productieregel. Hiervoor AA is een BB, gevolgd door een CC_SYM vereist. A BB is ook een productieregel. BB Daarom is het geen terminal. BB moet een JJ_SYM of een KK_SYM zijn. Zowel JJ_SYM als KK_SYM zijn terminals omdat ze niet de namen van andere productieregels zijn. CC_SYM is ook een terminal.

In de BNF voor X++-grammatica hebben de meeste terminals _SYM als achtervoegsel van hun naam.

Formele X++-grammatica in BNF

Deze sectie bevat het BNF dat de grammatica van X++ definieert.

    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

Aanvullende bronnen

X++ Taalreferentie