Notă
Accesul la această pagină necesită autorizare. Puteți încerca să vă conectați sau să modificați directoarele.
Accesul la această pagină necesită autorizare. Puteți încerca să modificați directoarele.
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:
|
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