Sintaxă X++

Notă

Grupurile de interes din comunitate s-au mutat acum din Yammer în Microsoft Viva Engage. Pentru a vă alătura unei comunități Viva Engage și a participa la cele mai recente discuții, completați formularul Solicitați acces la Finanțe și Operațiuni Viva Engage Community și alegeți comunitatea la care doriți să vă alăturați.

Acest articol conține referința de sintaxă pentru X++.

Cuvinte cheie X++

Cuvintele cheie X++ afișate în tabelul următor sunt rezervate. Aceste cuvinte cheie nu pot fi utilizate în niciun alt scop.

Cuvânt rezervat Descriere Informații corelate
! Nu. Operatori relaționali
!= Operator inegalitate (nu este egal cu). Operatori relaționali
# Prefix pentru numele macrocomenzilor. Cum să: Utilizați #define și #if pentru a testa o macrocomandă
& ȘI binar. Operatori aritmetici
&& LOGIC ȘI. Operatori relaționali
( Operator apel funcție, care indică începutul apelului funcției.
) Operator apel funcție, care indică sfârșitul apelului funcției.
* Multiplica. Asteriscă (*) este utilizată și în X++ SQL. O singură utilizare este să semnificați toate câmpurile din tabelele dintr-o select instrucțiune. O altă utilizare este ca un caracter wildcard cu like operatorul, pentru a semnifica de la 0 la mai multe caractere de orice fel. Operatorul like utilizează, de asemenea, caracterul ? . Operatori aritmetici
^ XOR binar. Operatori aritmetici
| OR binar. Operatori aritmetici
|| OR logic. Operatori relaționali
~ Nu. Operatori aritmetici
+ Plus. Operatori aritmetici
++ Creștere. Operatori de atribuire
+= Atribuire aditivă. Operatori de atribuire
, Operator virgulă. Expresiile separate prin virgulă sunt evaluate secvențial de la stânga la dreapta.
- Minus. Operatori aritmetici
-- Operator de decrementare. Operatori de atribuire
-= Atribuire subtractivă. Operatori de atribuire
. Operatorul de acces al membrului clasei, de exemplu, formRun.run accesează run metoda unui obiect de tipul FormRunde clasă .
/ Împărți. Operatori aritmetici
\ Scăpați în șiruri. Elimină ghilimelele suplimentare și anumite litere, cum ar fi "\t" pentru filă.
@ Evadarea cuvintelor cheie. De exemplu, var @str = 1@abstract; nu reușește compilarea fără @ caracterul care determină ca orice șir care îl urmează să fie considerat ca identificator. De asemenea, afectează șirurile literale, negatând efectul caracterului \ escape și permițând șirului să se întindă pe mai multe linii în codul sursă. Linia nouă este reprezentată printr-un caracter din 0x0A hexazecimal, numit de obicei flux de linii. Nu este inclus niciun caracter returnat de transport din 0x0D hexazecimal, ca în 0x0D0A.
: Caracterul două puncte (:) este utilizat pentru a delimita valorile de litere mari și mici din instrucțiune switch .
:: Utilizat pentru a apela metode statice (de clasă): ClassName::methodName() și pentru a desemna litere de enumerare, cum ar fi NoYes::Yes.
; Se termină instrucțiunile. Utilizat în for bucle sau ca separator al inițializatorului, actualizării și părților de verificare a valorii.
< Mai puţin. Operatori relaționali
<< Shift stânga. Operatori aritmetici
<= Mai mic sau egal. Operatori aritmetici
= Operator de atribuire. Argumentul din partea stângă a "=" este setat la valoarea argumentului la dreapta. Operatori de atribuire
== Returnează adevărat dacă expresiile sunt egale. Operatori relaționali
> Mai mare decât. Operatori relaționali
>= Mai mare sau egal. Operatori relaționali
>> Deplasare la dreapta la nivel de biți. Acest operator deplasează biții în partea stângă cu suma din partea dreaptă. Fiecare deplasare împarte efectiv numărul la 2^n, unde n este numărul de poziții mutate. Operatori aritmetici
?: Operator ternary. Caracterul semn de întrebare (?) este utilizat și de like operator pentru a semnifica exact un caracter de orice fel. Operatorul like utilizează și caracterul. Operator ternary (?)
[ Declarator matrice, deschis. Trebuie utilizat cu "]".
] Declarator matrice, închidere. Trebuie utilizat cu "[".
{ Pornește o instrucțiune compusă care poate conține la rândul său zero sau mai multe instrucțiuni. Instrucțiunea compusă se termină cu cea mai apropiată "}".
} Indică sfârșitul declarației compuse descrise mai sus. Un "{" trebuie să apară înaintea primei instrucțiuni.
abstract Modificator de clasă și metodă. O clasă abstractă nu poate fi construită cu noul cuvânt cheie - numai clasele derivate din el pot. Nu se poate apela o metodă abstractă , ci doar metode care o înlocuiesc. Un tabel poate fi modificat ca abstract prin setarea proprietății sale Abstracte la Da în AOT sau utilizând DictTable clasa. Proprietatea Abstractă este setată implicit la Nu și nu poate fi setată decât dacă tabelul este extins de alt tabel. Fiecare rând dintr-un tabel abstract trebuie să aibă un rând dependent într-un tabel derivat. Acest lucru înseamnă că fiecare rând dintr-un tabel abstract are o valoare mai mare decât zero în câmpul său de proprietate InstanceRelationType . Nu există alte efecte de la marcarea unui tabel ca abstract. Programatorii folosesc adesea termenul concret pentru a descrie o clasă care nu este abstractă. Metoda modificatorilor - Prezentare generală a moștenirii tabelului
orice tip Un tip care poate conține valori de orice tip. Orice tip
ca Este necesar atunci când atribuiți o variabilă de clasă de bază unei variabile de clasă derivate. De exemplu, dată fiind o Derived clasă care extinde o Base clasă, instrucțiunea myDerived = myBase as Derived; evită o eroare de compilator utilizând cuvântul cheie. Acest cuvânt cheie se aplică și atunci când atribuiți o variabilă de tabel de bază unei variabile de tabel derivate. Dacă valoarea (myBase) nu este de tipul desemnat (Derivat), expresia returnează null. Operatori expresie: Este și ca pentru moștenire
asc O opțiune pentru orderby clauza sau groupby dintr-o select instrucțiune. Sortarea este ascendentă. Selectare sintaxă instrucțiune
la Specifică poziția unei ferestre de imprimare ca parte a unei print instrucțiuni. Instrucțiunea de imprimare nu trebuie utilizată. Instrucțiuni de imprimare
Avg Returnează media câmpurilor din rândurile specificate de group by clauza dintr-o select instrucțiune. Selectare sintaxă instrucțiune
sparge Ieșire imediată dintr-un bloc de cod iterativ. Instrucțiuni întrerupere
Întrerupere Reprezintă un punct de întrerupere setat pentru depanare. Pentru a seta un punct de întrerupere în cod, scrieți: breakpoint;
lângă O parte a unui termen rezervat, cum ar fi grupare după și ordonare după.
byref Specifică faptul că parametrul transmis metodei apelate este transmis prin referință (adresă), nu după valoare. Byref este utilizat în X++ atunci când apelați o metodă .NET care preia un parametru prin referință (cum ar fi cu cuvintele cheie C# în afară sau ref). Cum să: Utilizați cuvântul cheie byref pentru CLR Interop.
caz Selecția dintr-o switch instrucțiune. Comutați instrucțiunile
prinde Utilizat în gestionarea excepțiilor. Gestionarea excepțiilor cu încercarea și prinderea cuvintelor cheie
changeCompany Modifică setările bazei de date în altă firmă. Modificare model proiectare firmă
clasă Declară o clasă. Clase în X++
client Modificator metodă. Acești modificatori nu mai sunt utilizați. Toate metodele sunt executate pe nivelul de server. Modificatoare metodă
container container Desemnează tipul. Containerele conțin o secvență de valori atomice și alte containere. Containere
continua Forțează următoarea iterație a unei bucle. Continuați instrucțiunile
număra Returnează numărul de înregistrări din rândurile specificate de group by clauza dintr-o select instrucțiune. Selectare sintaxă instrucțiune
crossCompany Determină ca o select instrucțiune să returneze date pentru toate firmele din care este autorizat utilizatorul să citească. Noțiuni de bază despre cod X++ inter-firmă
dată Specifică o variabilă de tip date. Date
Implicit Caz implicit în switch instrucțiuni. Blocul de cod din partea implicită este executat dacă valoarea argumentului nu corespunde niciuneia dintre case clauzele furnizate în switch instrucțiune. Comutați instrucțiunile
delegat Un membru al clasei care poate stoca mai multe referințe la metode din alte clase și pentru a apela toate metodele respective atunci când vi se solicită acest lucru. Un delegat poate stoca referințe la diferite tipuri de metode, inclusiv următoarele:
  • metode statice pe clasele X++
  • metode de instanță pentru clasele X++
  • metode pentru clasele .NET Framework
Comparație între Terminologia evenimentelor și cuvintele cheie X++, C#: Eveniment
delete_from Vă permite să ștergeți înregistrările din baza de date. delete_from
Desc O opțiune pentru order by clauza sau group by dintr-o select instrucțiune. Sortarea este descendentă. Selectare sintaxă instrucțiune
arăta Modificator metodă. Se utilizează o metodă de afișare</afișare> pentru a afișa valorile calculate într-un control de formular. Spre deosebire de câmpurile obișnuite, aceste valori nu sunt stocate în baza de date, dar sunt calculate dinamic. Modificatoare metodă
Div Împărțire întreagă. Operatori aritmetici
face Începutul unei do...while bucle. Face... în timp ce bucle
editare Modificator metodă. O edit metodă din X++ permite utilizatorilor să modifice valorile dintr-un control de formular în timp ce execută logica particularizată. Spre deosebire de display metode, care afișează doar valorile calculate, metodele de editare permit atât vizualizarea, cât și editarea. Modificatoare metodă
altfel Execuție condițională (if...else). Partea else din instrucțiune if se execută dacă expresia din instrucțiunea if este evaluată pentru false dacă și dacă ... instrucțiuni else
eventHandler Trebuie utilizat de fiecare dată când adăugați sau ștergeți o referință de metodă de la un delegat utilizând += operatorul sau -= . De exemplu: myDelegate += eventHandler(OtherClass::myStaticMethod); Comparație între Terminologia evenimentelor și cuvintele cheie X++, C#: Eveniment
Există Utilizat cu join clauze în select instrucțiuni. Selectare sintaxă instrucțiune
Extinde O clauză de declarație de clasă sau de interfață. Dacă clasa dvs. nu extinde în mod explicit altă clasă, clasa dvs. este considerată pentru a extinde Object clasa (ca și cum ați fi scris "extinde obiectul"). Crearea unei subclase
fals Literală booleană. Boolean
final Modificator de clasă și metodă. Specifică faptul că această metodă nu poate fi înlocuită. Modificatoare metodă
firstFast Utilizat în select instrucțiuni pentru a accelera preluarea pentru primul rând. Selectare sintaxă instrucțiune
în primul rând Utilizat în select instrucțiuni pentru a prelua doar prima înregistrare. Cuvântul firstOnly cheie nu garantează că maximum o înregistrare este regăsită de o instrucțiune SQL select X++. Dacă AOS poate utiliza EntireTable memoria cache pentru a satisface cerințele de date ale angajamentului select , cuvântul firstOnly cheie este ignorat. Selectare memorare în cache bazată pe sintaxa pentru instrucțiune
mai întâiOnly10 La fel ca în primul rând, cu excepția returnează 10 rânduri în loc de unul.
firstOnly100 La fel ca în primul rând, cu excepția returnează 100 de rânduri în loc de unul.
firstOnly1000 La fel ca în primul rând, cu excepția returnează 1.000 de rânduri în loc de unul.
culoare Golește memoria cache a întregului tabel. Acest lucru poate fi util atunci când doriți să vă asigurați că toate modificările aduse tabelului se reflectă imediat în operațiunile ulterioare. Memorare în cache bazată pe setare
pentru Pentru iterație în buclă. Pentru bucle
forceLiterals Utilizat în select instrucțiuni pentru a afișa valorile reale care sunt utilizate în where clauze pentru baza de date Microsoft SQL Server în momentul optimizării. Selectare sintaxă instrucțiune
forceNestedLoop Impune bazei de date SQL Server să utilizeze un algoritm de buclă imbricată pentru a procesa o anumită instrucțiune SQL care conține un join. Selectare sintaxă instrucțiune
forcePlaceholders Utilizat în select instrucțiuni pentru a instrui kernelul să nu dezvăluie valorile reale utilizate în clauzele bazei de date Microsoft SQL Server în where momentul optimizării. Selectare sintaxă instrucțiune
forceSelectOrder Impune bazei de date SQL Server să acceseze tabelele într-o asociere în ordinea specificată. Selectare sintaxă instrucțiune
forUpdate Selectează înregistrările exclusiv pentru actualizare. Operațiunea de efectuat asupra înregistrărilor preluate este o actualizare. În funcție de baza de date subiacentă, înregistrările pot fi blocate pentru alți utilizatori. Selectare sintaxă instrucțiune
din O parte a unei select declarații. from Clauza specifică tamponul de tabel în care există coloanele. Selectare sintaxă instrucțiune
grup O parte a clauzei group by într-o select instrucțiune. Selectare sintaxă instrucțiune
dacă Executarea condițională. dacă și dacă ... instrucțiuni else
Implementează Punerea în aplicare a unui interface. Prezentare generală interfețe
insert_recordset Copiază datele dintr-unul sau mai multe tabele într-un tabel destinație rezultat într-o singură călătorie de server. insert_recordset
Int Specifică o variabilă de tip integer (pe 32 de biți). Întregi
int64 Specifică o variabilă de tip integer (pe 64 de biți). Întregi
interfață Declarație de interfață. Prezentare generală interfețe
e Întreabă dacă obiectul la care face referire o variabilă de clasă fie moștenește de la clasa dată, fie este al clasei date. De exemplu, dată fiind o Derived clasă care extinde o Base clasă, expresia (myDerived is Base) returnează adevărat. Acest cuvânt cheie se aplică moștenirii clasei și moștenirii tabelelor. Operatori expresie: Este și ca pentru moștenire
alătura Tabelele sunt asociate în coloane comune ambelor tabele. Puteți genera un singur set de rezultate pe baza mai multor tabele utilizând asocieri. Selectare sintaxă instrucțiune
plăcea Testează potrivirile după model, cu simboluri wildcard "*" și "?". Operatori relaționali
maxof Returnează numărul maxim de câmpuri din rândurile specificate de group by clauză. Selectare sintaxă instrucțiune
minof Returnează minimul de câmpuri din rândurile specificate de group by clauză. Selectare sintaxă instrucțiune
mod Returnează restul expresiei din stânga1 împărțit la expresia din dreapta2. Informal, acest lucru se numește uneori operator de modulo. (12 mod 7) == 5 este adevărat.
nou Operator. Creează o instanță a unei clase sau alocă memorie pentru o matrice.
următor Preia următoarea înregistrare dintr-un tabel sau apelează următoarea metodă într-o secvență de comandă în lanț.
noFetch Indică faptul că nu vor fi preluate înregistrări acum. Selectare sintaxă instrucțiune
notExiști Utilizat cu join clauze în select instrucțiuni. Selectare sintaxă instrucțiune
zero Constantă simbolică.
optimistIcLock Impune ca o declarație să ruleze cu controlul optimist al concurenței, chiar dacă este setată o altă valoare în tabel. Selectare sintaxă instrucțiune
comanda O parte a clauzei order by într-o select instrucțiune. Selectare sintaxă instrucțiune
exterior unire exterioară. Selectare sintaxă instrucțiune
pauză Oprește executarea unei lucrări. Utilizatorului i se solicită să menționeze dacă executarea ar trebui să continue. Nu ar trebui să utilizați acest angajament în codul de producție. Selectare instrucțiuni
pesimistLock Impune ca o declarație să ruleze cu controlul concurenței pesimiste, chiar dacă este setată o altă valoare în tabel. Selectare sintaxă instrucțiune
tipări Vă permite să afișați ieșirea pe ecran. Nu ar trebui să utilizați acest angajament în codul de producție. Instrucțiuni de imprimare
privat Modificator de acces metodă. Metoda poate fi utilizată numai în cadrul clasei care declară metoda. Control metodă de acces
protejat Modificator de acces metodă. Metoda poate fi utilizată din metode din clasa care declară metodele și în orice clase derivate. Control metodă de acces
publice Modificator de acces metodă. Metoda se poate apela din orice clasă. Control metodă de acces
real real Desemnează tipul, un tip zecimal fără erori de rotunjire. Date reale
repetabilRead Specifică faptul că nicio altă tranzacție nu poate modifica datele care au fost citite logic în interiorul tranzacției curente, până când nu se termină tranzacția curentă. O tranzacție explicită se finalizează fie la ttsAbort , fie la ttsCommit exterior. Pentru o instrucțiune de selectare independentă, durata tranzacției este durata comenzii de selectare . Totuși, baza de date impune uneori echivalentul repetabilCitit în instrucțiuni de selectare individuale chiar și fără acest cuvânt cheie care apare în codul X++ (în funcție de modul în care baza de date decide să scaneze tabelele). Pentru mai multe informații, consultați documentația pentru produsul bază de date relațional.
Reîncercare Utilizat în gestionarea excepțiilor. Gestionarea excepțiilor cu încercarea și prinderea cuvintelor cheie
restitui Returnează dintr-o metodă. Declarație de metode
inversa Înregistrările sunt returnate în ordine inversă. Selectare sintaxă instrucțiune
alege select Clauza desemnează ce coloane sau vizualizări sunt afișate în setul de rezultate. Selectare instrucțiuni
server Modificator metodă. Acest modificator este ignorat și nu trebuie utilizat, deoarece toate metodele sunt executate pe partea server. Modificatoare metodă
setare Utilizat cu comanda update_recordset . update_recordset
static Metodele statice pot să nu facă referire la variabile instanță (numai la variabile statice); poate fi invocată utilizând numele clasei în loc de o instanță a clasei ("MyClass.aStaticProcedure"). Modificatoare metodă
Str string Desemnează tipul. Siruri
sumă Returnează suma câmpurilor din rândurile specificate de group by clauză într-o select instrucțiune. Selectare sintaxă instrucțiune
Super Apelează metoda care a fost înlocuită de metoda curentă. Metode tabel
comutator Instrucțiunea Switch. Comutați instrucțiunile
tableLock Învechit; tableLock nu mai este disponibil.
acest O referință la instanța curentă a clasei. Utilizat în cod X++ într-o metodă de instanță a clasei. Utilizat pentru a face referire la membrii clasei.
arunca Utilizat în gestionarea excepțiilor. Gestionarea excepțiilor cu încercarea și prinderea cuvintelor cheie
adevărat Literală booleană. Boolean
încerca Utilizat în gestionarea excepțiilor. Gestionarea excepțiilor cu încercarea și prinderea cuvintelor cheie
ttsAbort Revenire (adică renunțare) la toate modificările din tranzacția curentă. Integritate tranzacție
ttsBegin Marchează începutul unei tranzacții. Integritate tranzacție
ttsCommit Marchează sfârșitul unei tranzacții, comiterea modificărilor în tabele. Integritate tranzacție
update_recordset Permite manipularea seturilor de rânduri într-o singură operațiune. update_recordset
validTimeState Filtrează rândurile regăsite dintr-un tabel de stare de timp valid după o instrucțiune SQL select X++. De exemplu: selectați validTimeState(myDateEffective) * din xMyTable; ... sau... select validTimeState(myDateFrom, myDateTo) * from xMyTable; Efectele tabelelor de stare de timp valide în operațiunile de citire și scriere
nul Identifică o metodă care nu returnează o valoare. Declarație de metode
unde O parte a unei select declarații. where Clauza specifică condițiile de îndeplinit; mai exact, rândurile pe care doriți să le includeți în rezultat. Selectare sintaxă instrucțiune
vreme Instrucțiunea iterației. Execută o instrucțiune în mod repetat, atât timp cât condiția testului este adevărată. În timp ce se repetă buclele în timp ce selectați Instrucțiuni
fereastră Vă permite să modificați dimensiunea ferestrei de ieșire. Utilizat cu instrucțiuni de imprimare</imprimare> care nu sunt recomandate în codul de producție. Instrucțiuni de imprimare

Sintaxă expresii

O expresie din X++ este utilizată în mod matematic sau logic. Expresiile sunt construite pe tipurile de date ale limbii; adică o expresie returnează întotdeauna o valoare de un anumit tip. Această valoare poate fi utilizată în calcule, atribuiri, instrucțiuni condiționale și așa mai departe.

Descrierea EBNF a expresiilor în X++

Termen   Definiție
Expression = Expresie simplă [RelationalOperator Simple-expression ]
RelationalOperator = =
Expresie simplă = Expresie simplă [ +
Termen = Compfactor { Mult-operator CompFactor }
Operator mult = *
CompFactor = [ ! ] [ -
Factor = Literală
Enum = EnumName :: Literal
Variabil = Identificator [ [ Expresie ] ] [ . Expresie ]
Apel funcție = [ Expresie (.
Dacă-expresie = Expresie? Expresie : Expresie

Restricțiile semantice se aplică la sintaxa anterioară. Nu puteți apela nicio metodă utilizând operatorul :: În mod similar, nu puteți utiliza acest cuvânt cheie fără un obiect activ; adică, dacă nu vă aflați într-o metodă de instanță și așa mai departe.

Exemple

Exemplu de expresie Descriere
1 Un întreg literal.
NoYes::Nu O referință de enumerare.
A O referință variabilă.
Debitor::Find("1") Un apel de metodă static (returnează o variabilă de client).
(A > 3 ? true : false) O expresie dacă returnează adevărat sau fals.
(selectați CustTable unde CustTable.Account == "100"). NameRef O expresie de selectare. Returnează câmpul nameref din tabelul client. Acesta este un șir.
A >= B O expresie logică. Returnează adevărat sau fals.
A + B O expresie aritmetică. Însumează A și B.
A + B / C Calculează B/C, apoi o adaugă la A.
~A + asta. Value() Însumează binarul nu A și rezultatul valorii de apelare a metodei pe obiectul din domeniu (acest lucru).
Debitor::Find("1"). NameRef Returnează câmpul NameRef al înregistrării clientului găsit.
Debitor::Find("1"). Sold() O metodă de apelare a Balance tabelului de clienți (Debitor::Find returnează un client). Returnează soldul clientului cu numărul 1 al contului.

Prezentare generală EBNF

Extended Backus Naur Form (EBNF) este un metalanguage și este utilizat în acest ghid pentru a descrie sintaxa de limbă. O definiție EBNF constă în reguli de producție, neterminale și terminale. Termenii cheie sunt afișați în tabelul următor.

Termeni-cheie Exemplu Descriere
Terminale Work_Team Un terminal este un caracter sau un șir de caractere care nu se modifică niciodată.
Neterminale Employee O descriere neterminală este o descriere a unei propoziții valide în limba definită fie de o regulă de producție, fie de o descriere textuală. Un simbol neterminal poate fi întotdeauna extins la unul sau mai multe simboluri terminale.
Reguli de producție Angajat = Dezvoltator Tester

Exemplu

Work_Team = Angajat manager {, Angajat} angajat = Dezvoltator | Tester Acest exemplu definește un Work_Team ca constând dintr-un Manager și unul sau mai multe Employees. Un Employee este definit ca fiind un Developer, sau un Tester. Simbolurile utilizate în exemplu sunt descrise în tabelul următor.

Simboluri speciale în EBNF

Simbol Descriere
(Expresie) Parantezele păstrează simbolurile (terminale și nonterminale) împreună. Acestea pot fi plasate oriunde în partea dreaptă a unei reguli de producție.
Expresie1 Expresie2
[Expresie] Opțional: Elementele dintre [ și ] sunt opționale. Sunt incluse toate elementele sau niciunul dintre elementele din paranteze.
{Expression} Repetare: Elementele dintre { și } sunt opționale, dar pot fi repetate de câte ori este necesar.

De exemplu, dacă accesoriile pe care le cumpărați pentru bicicletă constau dintr-o șale, deținători de sticle de apă, clopoței și coarne și ați putea avea fie un clopoțel, fie un corn, iar unul sau mai mulți deținători de sticlă de apă și exact o șa, aceasta poate fi exprimată ca: Bicycle_Accessories = șaa [coarnă | corn] {water_bottle_holders} Această gramatică definește următoarele posibilități: saddlesaddle bellsaddle horn șa water_bottle_holder clopoțel de șa water_bottle_holder clopoțel water_bottle_holder water_bottle_holder și așa mai departe.

X++ Gramatică

Acest articol arată gramatica formală a limbii X++.

Cum se interpretează gramatica formală BNF

Această secțiune descrie gramatica X++ în formularul Backus Naur (BNF). Un mic exemplu de BNF este descris aici.

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

AA este numele unei reguli de producție. Un AA necesită un BB, urmat de un CC_SYM. A BB este, de asemenea, o regulă de producție. Prin urmare, BB nu este un terminal. BB trebuie să fie un JJ_SYM sau un KK_SYM. Atât JJ_SYM cât și KK_SYM sunt terminale, deoarece nu sunt numele altor reguli de producție. CC_SYM este, de asemenea, un terminal.

În gramatica BNF pentru X++ , majoritatea terminalelor au _SYM ca sufix al numelui lor.

Gramatică formală X++ în BNF

Această secțiune conține BNF care definește gramatica X++.

    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

Resurse suplimentare

Referință limbă X++