Deila með


Málskipan X++

Athugið

Hagsmunahópar samfélagsins hafa nú færst frá Yammer yfir í Microsoft Viva Engage. Til að ganga í Viva Engage samfélag og taka þátt í nýjustu umræðum skaltu fylla út eyðublaðið Biðja um aðgang að Finance and Operations Viva Engage Community og velja samfélagið sem þú vilt ganga í.

Þessi grein inniheldur setningafræðitilvísun fyrir X++.

X++ Leitarorð

X++ leitarorðin sem sýnd eru í eftirfarandi töflu eru frátekin. Þessi leitarorð er ekki hægt að nota í neinum öðrum tilgangi.

Frátekið orð lýsing Tengdar upplýsingar
! Ekki. Venslaðir rekstraraðilar
!= Ójöfnuður rekstraraðili (ekki jafnt). Venslaðir rekstraraðilar
# Forskeyti á fjölvanöfnum. Hvernig á að: Nota #define og #if til að prófa makró
& Tvöfalt OG. Reiknivirkjar
&& Rökrétt OG. Venslaðir rekstraraðilar
( Aðgerðasímtalsvirki, sem gefur til kynna upphaf aðgerðakallsins.
) Rekstraraðili aðgerðasímtals, sem gefur til kynna lok aðgerðakallsins.
* Margfalda. Stjarnan (*) er einnig notuð í X++ SQL. Ein notkun er að tákna alla reiti úr töflunum á fullyrðingu select . Önnur notkun er sem jokertákn með rekstraraðilanum like , til að tákna 0 fyrir marga stafi af hvaða tagi sem er. Rekstraraðilinn like notar einnig ? stafinn. Reiknivirkjar
^ Tvöfalt XOR. Reiknivirkjar
| Tvöfalt OR. Reiknivirkjar
|| Rökrétt EÐA. Venslaðir rekstraraðilar
~ Ekki. Reiknivirkjar
+ Plús. Reiknivirkjar
++ Increment. Virkjar úthlutunar
+= Aukefni verkefni. Virkjar úthlutunar
, Kommu rekstraraðila. Segðir aðskildar með kommum eru metnar í röð frá vinstri til hægri.
- Mínus. Reiknivirkjar
-- Lækkun rekstraraðila. Virkjar úthlutunar
-= Frádráttarverkefni. Virkjar úthlutunar
. Aðgangsstýring klasameðlima, til dæmis, formRun.run fær aðgang að run aðferð hlutar af klasagerðinni FormRun.
/ Skipta. Reiknivirkjar
\ Flýja í strengjum. Sleppir við auka gæsalappir og tilteknum bókstöfum eins og '\t' fyrir flipa.
@ Flótti leitarorða. Til dæmis var @str = 1@abstract; tekst ekki að safna saman án þess að stafurinn @ sem veldur því að einhver strengur á eftir honum er talinn auðkenni. Það hefur einnig áhrif á bókstaflega strengi, með því að afneita áhrifum \ escape-stafsins, og með því að gera strengnum kleift að spanna fleiri en eina línu í frumkóðanum. Nýja línan er táknuð með einum staf af sextánda 0x0A, sem er almennt kallað línufóður. Enginn vagnaskilastafur sextándakerfis 0x0D er innifalinn, eins og í 0x0D0A.
: Tvípunktur (:) stafurinn er notaður til að afmarka hástafagildi í fullyrðingunni switch .
:: Notað til að kalla statískar (class) aðferðir: ClassName::methodName() og til að tilgreina upptalningarbókstafi, eins og NoYes::Yes.
; Lýkur yfirlýsingum. Notað í for lykkjum eða sem aðskilnaður á frumstillingu, uppfærslu og gildisávísunarhlutum.
< Minna en. Venslaðir rekstraraðilar
<< Vinstri vakt. Reiknivirkjar
<= Minna en eða jafnt. Reiknivirkjar
= Rekstraraðili verkefnis. Rökin vinstra megin við "=" eru stillt á gildi röksemdafærslunnar til hægri. Virkjar úthlutunar
== Skilar true ef segðirnar eru jafnar. Venslaðir rekstraraðilar
> Meiri en. Venslaðir rekstraraðilar
>= Meiri en eða jafnt. Venslaðir rekstraraðilar
>> Bitwise hægri skipting. Þessi virki færir bita vinstra megin um upphæðina hægra megin. Hver vakt deilir í raun tölunni með 2^n, þar sem n er fjöldi staða sem færðar eru. Reiknivirkjar
?: Þrískiptur rekstraraðili. Spurningarmerkið (?) stafurinn er einnig notaður af rekstraraðilanum like til að tákna nákvæmlega einn staf af einhverju tagi. Rekstraraðilinn like notar einnig stafinn . Þrískiptur rekstraraðili (?)
[ Fylkisyfirlýsing, opinn. Verður að nota með "]".
] Fylkisyfirlýsing, nálægt. Verður að nota með "[".
{ Byrjar samsetta fullyrðingu sem aftur getur innihaldið núll eða fleiri fullyrðingar. Samsetta fullyrðingin endar á næst samsvarandi "}".
} Gefur til kynna lok samsettrar fullyrðingar sem lýst er hér að ofan. "{" verður að koma fyrir á undan fyrstu þessara fullyrðinga.
útdráttur Flokks- og aðferðarbreytir. Ekki er hægt að smíða abstrakt flokk með nýja leitarorðinu - Aðeins flokkarnir sem dregnir eru af honum geta það. Ekki er hægt að kalla abstrakt aðferð, aðeins aðferðir sem hnekkja henni geta það. Hægt er að breyta töflu sem abstrakt með því að stilla eiginleika hennar Abstract á Yes í AOT, eða með því að nota flokkinn DictTable . Eiginleikinn Abstract er sjálfgefið Nei og ekki er hægt að stilla hann nema taflan sé stækkuð með annarri töflu. Hver lína í óhlutbundinni töflu verður að hafa háða línu í afleiddri töflu. Þetta þýðir að hver lína í abstrakttöflu hefur gildi sem er stærra en núll í eiginleikareitnum InstanceRelationType . Það eru engin önnur áhrif af því að merkja borð sem abstrakt. Óformlega nota forritarar oft hugtakið áþreifanlegt til að lýsa flokki sem er ekki óhlutbundinn. Yfirlit yfir erfðir aðferðabreytinga
hvaða tegund sem er Gerð sem getur innihaldið gildi af hvaða gerð sem er. Hvaða tegund sem er
sem Nauðsynlegt þegar grunnklasabreytu er úthlutað á afleidda klasabreytu. Til dæmis, miðað við klasa Derived sem framlengirBase klasa, forðast fullyrðingin myDerived = myBase as Derived; þýðandavillu með því að nota as leitarorðið. Þetta leitarorð á einnig við þegar þú úthlutar grunntöflubreytu á afleidda töflubreytu. Ef gildið (myBase) er ekki af tilgreindri gerð (Afleidd) skilar segðin núll. Tjáningarvirkjar: er og eins og fyrir erfðir
ASC Valmöguleiki á eðaorder ákvæðinu bygroup í yfirlýsinguby.select Flokkunin fer hækkandi. Velja setningafræði yfirlits
hjá Tilgreinir staðsetningu prentglugga sem hluta af print uppgjöri. Ekki ætti að nota prentyfirlýsinguna. Prenta yfirlit
Avg Skilar meðaltali reita úr línunum sem tilgreindar eru af klausunni group by í select yrðingu. Velja setningafræði yfirlits
brjóta Farðu strax úr endurtekinni kóðablokk. Brot yfirlýsingar
Brotpunktur Táknar brotpunkt sem er stillt fyrir kembiforrit. Til að setja brotpunkt í kóðanum þínum skaltu skrifa: breakpoint;
hjá Hluti af fráteknu hugtaki, svo sem flokka eftir og raða eftir.
byref Tilgreinir að færibreytan sem verið er að senda í kallaða aðferð sé send með tilvísun (vistfangi), í stað þess að fara með gildi. Byref er notað í X++ þegar kallað er á .NET aðferð sem tekur færibreytu með tilvísun (eins og með C# lykilorðin út eða tilvísun). Hvernig á að: Nota leitarorðið fyrir CLR Interop.
tilfelli Val innan yfirlýsingar switch . Skipta um yfirlýsingar
afli Notað við meðhöndlun undantekninga. Undantekning meðhöndlun með reyna og grípa Lykilorð
changeCompany Breytir gagnagrunnsstillingum í annað fyrirtæki. Breyttu hönnunarmynstri fyrirtækisins
farrými Lýsir yfir flokki. Námskeið í X++
skjólstæðingur Breytir aðferð. Þessar breytingar eru ekki notaðar lengur. Allar aðferðir eru keyrðar á netþjónastiginu. Aðferðir breytir
gámur Tilgreinir tegundina container . Ílát innihalda röð atómgilda og annarra íláta. Ílát
halda áfram Þvingar fram næstu endurtekningu lykkju. Halda áfram yfirlýsingum
telja Skilar fjölda færslna úr línunum sem tilgreindar eru af setningunni group by í select yrðingu. Velja setningafræði yfirlits
crossCompany Veldur select því að yfirlýsing skilar gögnum fyrir öll fyrirtæki sem notandinn hefur heimild til að lesa frá. Grunnatriði X++ kóða þvert á fyrirtæki
dagsetning Tilgreinir breytu af gerðinni date. Dagsetningar
sjálfgefinn Sjálfgefið mál innan switch fullyrðinga. Kóðablokkin í sjálfgefna hlutanum er framkvæmd ef skiptigildið passar ekki við nein ákvæði sem case gefin eru upp í yfirlýsingunni switch . Skipta um yfirlýsingar
fulltrúi Bekkjarmeðlimur sem getur geymt margar tilvísanir í aðferðir í öðrum flokkum og kallað á allar þær aðferðir þegar hann er beðinn um það. Fulltrúi getur geymt tilvísanir í ýmiss konar aðferðir, þar á meðal eftirfarandi:
  • statískar aðferðir á X++ flokkum
  • tilviksaðferðir á X++ flokkum
  • aðferðir í .NET Framework klasa
Atburðahugtök og leitarorð X++, C# Samanburður: Atburður
delete_from Gerir þér kleift að eyða færslum úr gagnagrunninum. delete_from
Desc Valmöguleiki á eða ákvæðinu order by í yfirlýsingugroup by.select Flokkunin er lækkandi. Velja setningafræði yfirlits
skjár Breytir aðferð. Birtingar<-/birtingaraðferð> er notuð til að sýna reiknuð gildi í skjámyndstýringu. Ólíkt venjulegum reitum eru þessi gildi ekki geymd í gagnagrunninum heldur eru þau reiknuð á virkan hátt. Aðferðir breytir
Div Heiltölu skipting. Reiknivirkjar
gera Upphaf do...while lykkju. Gera... á meðan lykkjur
klippa Breytir aðferð. Aðferð edit í X++ gerir notendum kleift að breyta gildum í formstýringu á meðan sérsniðin rökfræði er keyrð. Ólíkt display aðferðum, sem sýna aðeins reiknuð gildi, gera breytingaraðferðir bæði kleift að skoða og breyta. Aðferðir breytir
annars Skilyrt framkvæmd (if...else). Hluti else yfirlýsingarinnar er framkvæmdur if ef tjáningin í if yfirlýsingunni er metin til false ef og ef ... annars yfirlýsingar
eventHandler Verður að nota í hvert sinn sem annaðhvort er bætt við eða eytt tilvísun í aðferð frá fulltrúa með því að nota operatorinn += eða -= . Til dæmis: myDelegate += eventHandler(OtherClass::myStaticMethod); Atburðahugtök og leitarorð X++, C# Samanburður: Atburður
Til Notað með join setningum í select fullyrðingum. Velja setningafræði yfirlits
Nær Yfirlýsingarákvæði um klasa eða viðmót. Ef bekkurinn þinn framlengir ekki beinlínis annan flokk, er bekkurinn þinn talinn lengja bekkinn (eins og Object þú hefðir skrifað "framlengir hlut"). Að búa til undirflokk
falskur Boolean bókstaflegt. Booleans
endanlegur Flokks- og aðferðarbreytir. Tilgreinir að ekki sé hægt að hnekkja þessari aðferð. Aðferðir breytir
firstFast Notað í yrðingum select til að flýta fyrir sækja fyrir fyrstu línuna. Velja setningafræði yfirlits
fyrstaAðeins Notað í yrðingum select til að sækja aðeins fyrstu færsluna. Lykilorðið firstOnly tryggir ekki að að hámarki ein færsla sé sótt með X++ SQL-setningu select . Ef AOS getur notað EntireTable skyndiminni til að fullnægja gagnakröfum fullyrðingarinnar select er lykilorðið firstOnly hunsað. Veldu skyndiminni sem byggir á yfirlitssetningasafni
fyrstaAðeins10 Sama og firstOnly, nema skilar 10 línum í stað einnar línu.
fyrstaAðeins100 Sama og firstOnly, nema skilar 100 línum í stað einnar línu.
fyrstaAðeins1000 Sama og firstOnly, nema skilar 1.000 línum í stað einnar línu.
Roði Hreinsar allt skyndiminni töflunnar. Þetta getur verið gagnlegt þegar tryggja á að allar breytingar sem gerðar eru á töflunni endurspeglist strax í síðari aðgerðum. Skyndiminni sem byggir á setti
handa Fyrir endurtekningu lykkju. Fyrir lykkjur
forceLiterals Notað í yrðingum select til að sýna raunveruleg gildi sem eru notuð í where klausum í Microsoft SQL Server gagnagrunninum við fínstillingu. Velja setningafræði yfirlits
forceNestedLoop Neyðir SQL Server gagnagrunninn til að nota hreiðrað reiknirit til að vinna úr tiltekinni SQL fullyrðingu sem inniheldur .join Velja setningafræði yfirlits
kraftStaðgenglar Notað í select fullyrðingum til að gefa kjarnanum fyrirmæli um að birta ekki raunveruleg gildi sem notuð eru í where klausum í Microsoft SQL Server gagnagrunninum við fínstillingu. Velja setningafræði yfirlits
forceSelectOrder Þvingar SQL Server gagnagrunninn til að fá aðgang að töflunum í samskeyti í tilgreindri röð. Velja setningafræði yfirlits
fyrirUppfæra Velur færslur eingöngu til uppfærslu. Aðgerðin sem á að framkvæma á færslum sem sóttar eru er uppfærsla. Það fer eftir undirliggjandi gagnagrunni, færslurnar geta verið læstar fyrir aðra notendur. Velja setningafræði yfirlits
frá Hluti af yfirlýsingu select . Ákvæðið from tilgreinir töflubiðminni þar sem dálkarnir eru til. Velja setningafræði yfirlits
hópur Hluti af ákvæðinu group by í yfirlýsingu select . Velja setningafræði yfirlits
ef Skilyrt framkvæmd. ef og ef ... annars yfirlýsingar
Framkvæmd Framkvæmd .interface Yfirlit yfir tengi
insert_recordset Afritar gögn úr einni eða fleiri töflum í eina áfangatöflu á einni þjónsferð. insert_recordset
Int Tilgreinir breytu af gerð integer (32-bita). Heiltölur
int64 Tilgreinir breytu af gerð integer (64-bita). Heiltölur
Tengi Yfirlýsing viðmóts. Yfirlit yfir tengi
Er Spyr hvort hluturinn sem klasabreytan vísar til erfi annað hvort frá tilteknum flokki eða sé af tilteknum flokki. Til dæmis, ef um er að ræða klasa Derived sem framlengirBase klasa, skilar tjáningin (myDerived is Base)true. Þetta leitarorð á við um erfðir flokka og töfluarfleifð. Tjáningarvirkjar: er og eins og fyrir erfðir
tengja Töflur eru sameinaðar í dálkum sem eru sameiginlegir báðum töflum. Hægt er að mynda eitt niðurstöðusafn byggt á mörgum töflum með því að nota samtengingar. Velja setningafræði yfirlits
eins og Prófanir á samsvörun eftir mynstri, með algildistáknum '*' og '?'. Venslaðir rekstraraðilar
Maxof Skilar hámarki reita úr línunum sem tilgreindar eru í klausunni group by . Velja setningafræði yfirlits
minof Skilar lágmarki reita úr línunum sem tilgreindar eru í klausunni group by . Velja setningafræði yfirlits
Mod Skilar heiltölu sem eftir er af vinstri segði1 deilt með hægri segði2. Óformlega er þetta stundum kallað modulo operator. (12 mod 7) == 5 er satt.
Nýtt Virki. Býr til tilvik af klasa eða úthlutar minni fyrir fylki.
næstur Sækir næstu færslu í töflu eða kallar á næstu aðferð í skipanakeðju.
noFetch Gefur til kynna að engar færslur eigi að sækja núna. Velja setningafræði yfirlits
ekkiTilvist Notað með join setningum í select fullyrðingum. Velja setningafræði yfirlits
núll Táknrænn fasti.
bjartsýniLás Þvingar fullyrðingu til að keyra með bjartsýnni samhliðastýringu, jafnvel þótt annað gildi sé stillt á töfluna. Velja setningafræði yfirlits
pöntun Hluti af ákvæðinu order by í yfirlýsingu select . Velja setningafræði yfirlits
Ytri ytri samskeyti. Velja setningafræði yfirlits
Gera hlé Stöðvar framkvæmd verks. Notandinn er beðinn um að tilgreina hvort framkvæmd eigi að halda áfram. Þú ættir ekki að nota þessa fullyrðingu í framleiðslukóða. Veldu yfirlit
svartsýnnLás Þvingar fullyrðingu til að keyra með svartsýnni samhliðastýringu, jafnvel þótt annað gildi sé stillt á töfluna. Velja setningafræði yfirlits
prenta Gerir þér kleift að birta úttak á skjánum. Þú ættir ekki að nota þessa fullyrðingu í framleiðslukóða. Prenta yfirlit
einka Breytir aðgangi að aðferð. Aðferðina er aðeins hægt að nota innan flokksins sem lýsir yfir aðferðinni. Aðferð aðgangsstýring
Vernda Breytir aðgangi að aðferð. Aðferðina er hægt að nota úr aðferðum í flokknum sem lýsir yfir aðferðunum og í hvaða afleidda flokki sem er. Aðferð aðgangsstýring
opinber Breytir aðgangi að aðferð. Aðferðina má kalla frá hvaða bekk sem er. Aðferð aðgangsstýring
raunverulegur Tilgreinir gerðina real , tugabrot án námundunarvillna. Raunveruleikar
endurtekiðLesa Tilgreinir að engar aðrar færslur geti breytt gögnum sem hafa verið lesin með rökum í núverandi færslu, fyrr en eftir að núverandi færslu er lokið. Skýrri færslu lýkur annað hvort ttsAbort eða ysta ttsCommit. Fyrir sjálfstætt select-yfirlit er lengd færslunnar lengd select-skipunarinnar. Hins vegar framfylgir gagnagrunnurinn stundum jafngildi endurtekinna Read í einstökum völdum fullyrðingum, jafnvel án þess að þetta leitarorð komi fram í X++ kóðanum þínum (fer eftir því hvernig gagnagrunnurinn ákveður að skanna töflurnar). Frekari upplýsingar er að finna í fylgiskjölum fyrir undirliggjandi venslagagnagrunnsafurð.
Reyna Notað við meðhöndlun undantekninga. Undantekning meðhöndlun með reyna og grípa Lykilorð
skila Skilar frá aðferð. Yfirlýsing um aðferðir
öfugur Færslum er skilað í öfugri röð. Velja setningafræði yfirlits
velja Klausan select tilgreinir hvaða dálkar eða yfirlit eru sýnd í niðurstöðusettinu. Veldu yfirlit
netþjónn Breytir aðferð. Þessi breytir er hunsuð og ætti ekki að nota hana, þar sem allar aðferðir eru keyrðar á netþjónshliðinni. Aðferðir breytir
stilling Notað með update_recordset skipuninni. update_recordset
Truflanir Kyrrstæðar aðferðir mega ekki vísa til tilviksbreytna (aðeins til kyrrstæðra breytna); hægt að kalla fram með því að nota klasaheitið frekar en á tilviki klasans ("MyClass.aStaticProcedure"). Aðferðir breytir
Str Tilgreinir tegundina string . Band
summa Skilar summu reitanna úr línunum sem tilgreindar eru af klausunni group by í select uppgjöri. Velja setningafræði yfirlits
frábær Kallar aðferðina sem var hnekkt með núverandi aðferð. Aðferðir við töflu
rofi Skipta um yfirlýsingu. Skipta um yfirlýsingar
tableLock Úreltur; tableLock er ekki lengur í boði.
þessi Tilvísun í núverandi tilvik flokksins. Notað í X++ kóða inni í tilviksaðferð bekkjarins. Notað til að vísa til aðferðarmeðlima bekkjarins.
kasta Notað við meðhöndlun undantekninga. Undantekning meðhöndlun með reyna og grípa Lykilorð
sannur Boolean bókstaflegt. Booleans
reyna Notað við meðhöndlun undantekninga. Undantekning meðhöndlun með reyna og grípa Lykilorð
ttsHætta við Afturkalla (þ.e. fleygja) öllum breytingum á núverandi færslu. Heiðarleiki viðskipta
ttsByrja Markar upphaf viðskipta. Heiðarleiki viðskipta
ttsSkuldbinda sig Merkir lok færslu og skuldbindur breytingarnar á töflunum. Heiðarleiki viðskipta
update_recordset Leyfir meðhöndlun línusetta innan einnar aðgerðar. update_recordset
validTimeState Síar línur sem eru sóttar úr gildri tímastöðutöflu með X++ SQL-setningu select . Til dæmis: veldu validTimeState(myDateEffective) * frá xMyTable; ... eða... veldu validTimeState(myDateFrom, myDateTo) * frá xMyTable; Áhrif gildra tímastöðutaflna á les- og skrifaðgerðir
Ógilda Auðkennir aðferð sem skilar ekki gildi. Yfirlýsing um aðferðir
hvar Hluti af yfirlýsingu select . Klausan where tilgreinir skilyrðin sem á að uppfylla, þ.e. línurnar sem á að hafa með í niðurstöðunni. Velja setningafræði yfirlits
meðan Yfirlýsing um endurtekningu. Framkvæmir fullyrðingu ítrekað svo framarlega sem prófunarskilyrðið er satt. While lykkjar á meðan þú velur Fullyrðingar
gluggi Gerir þér kleift að breyta stærð úttaksgluggans. Notað með prentunar<-/prentunaryrðingum> sem ekki er mælt með í framleiðslukóða. Prenta yfirlit

Setningafræði tjáningar

Tjáning í X++ er notuð annað hvort á stærðfræðilegan eða röklegan hátt. Segðir eru byggðar á gagnagerðum tungumálsins; það er, segð skilar alltaf gildi af einhverri gerð. Þetta gildi er hægt að nota í útreikningum, úthlutunum, skilyrtum fullyrðingum og svo framvegis.

EBNF lýsing á tjáningum í X++

Hugtak   Skilgreining
Segð = Einföld tjáning [RelationalOperator Einföld tjáning]
RelationalOperator = =
Einföld tjáning = Einföld tjáning [ +
Hugtak = Compfactor { Mult-virki CompFactor }
Fjölbreytilegur rekstraraðili = *
CompFactor = [ ! ] [ -
Stuðull = Bókstaflegur
Upptalning = EnumName :: Bókstaflegt
Breyta = Auðkenni [ [ Tjáning ] ] [ . Tjáning ]
Aðgerð Hringja = [ Tjáning (.
Ef-tjáning = Tjáning? Tjáning : Tjáning

Merkingartakmarkanir gilda um setningafræði á undan. Þú getur ekki kallað á neina aðferð með því að nota :: virkjann. Á sama hátt geturðu ekki notað þetta leitarorð án virks hlutar; það er að segja ef þú ert ekki innan tilviksaðferðar og svo framvegis.

Dæmi

Dæmi um tjáningu lýsing
1 Heiltala bókstafleg.
NeiJá::Nei Enum-tilvísun.
A Breytileg tilvísun.
Skuldari::Finna("1") Kyrrstætt aðferðakall (skilar breytu viðskiptavinar).
(A > 3 ? satt : rangt) If-segð sem skilar satt eða ósatt.
(veldu CustTable þar sem CustTable.Account == "100"). NafnRef Val-tjáning. Skilar reitnum nameref í viðskiptavinatöflunni. Þetta er strengur.
A >= B Rökrétt tjáning. Skilar satt eða ósatt.
A + B Reiknileg tjáning. Summur A og B.
A + B / C Reiknar B/C og bætir þessu síðan við A.
~A + þetta. Gildi() Summur tvíundar, ekki A og niðurstaða aðferðakallsins Gildi á hlutinn í umfangi (þetta).
Skuldari::Finna("1"). NafnRef Skilar NameRef reitnum fyrir færslu viðskiptavinar sem fannst.
Skuldari::Finna("1"). Jafnvægi () Aðferðarkall í Balance viðskiptavinatöflunni (Skuldari::Finna skilar viðskiptavini). Skilar stöðu viðskiptavinar með reikningsnúmeri 1.

EBNF Yfirlit

Extended Backus Naur Form (EBNF) er metamál og er notað í þessari handbók til að lýsa setningafræði tungumálsins. EBNF skilgreining samanstendur af framleiðslureglum, nonterminals og terminals. Lykilhugtökin eru sýnd í eftirfarandi töflu.

Lykilhugtök Dæmi lýsing
Skautanna Work_Team Flugstöð er einn stafur eða strengur stafa sem breytist aldrei.
Óstöðvandi Employee Óendanleg er lýsing á hluta gildrar setningar á tungumálinu sem er skilgreind annað hvort með framleiðslureglu eða textalýsingu. Óendatákn er alltaf hægt að stækka í eitt eða fleiri endatákn.
Framleiðslureglur Starfsmaður = Hönnuður Prófunartæki

Dæmi

Work_Team = Framkvæmdastjóri Starfsmaður {, Starfsmaður} Starfsmaður = Hönnuður | Prófari Þetta dæmi skilgreinir Work_Team sem samanstendur af a Manager og einum eða fleiri Employees. An Employee er skilgreint sem , Developereða a Tester. Táknunum sem notuð eru í dæminu er lýst í eftirfarandi töflu.

Sérstök tákn í EBNF

Tákn lýsing
(Tjáning) Svigar halda táknunum (útstöðvum og óútstöðva) saman. Hægt er að setja þær hvar sem er hægra megin við framleiðslureglu.
Tjáning 1 Tjáning 2
[Tjáning] Valfrjálst: Atriðin á milli [ og ] eru valfrjáls. Allir eða engir hlutir í sviga eru innifaldir.
{Tjáning} Endurtaka: Atriðin á milli { og } eru valkvæð, en hægt er að endurtaka þau eins oft og þörf krefur.

Til dæmis, ef fylgihlutirnir sem þú kaupir fyrir hjólið þitt samanstanda af hnakk, vatnsflöskuhaldara, bjöllum og hornum, og þú gætir haft annað hvort bjöllu eða horn, og núll, einn eða fleiri vatnsflöskuhaldara, og nákvæmlega einn hnakk, gæti þetta verið tjáð sem: Bicycle_Accessories = hnakkur [bjalla | horn] {water_bottle_holders} Þessi málfræði skilgreinir eftirfarandi möguleika: saddlesaddle bellsaddle horn hnakkur water_bottle_holder hnakkbjalla water_bottle_holder hnakkbjalla water_bottle_holder water_bottle_holder Og svo framvegis.

X++ málfræði

Þessi grein sýnir formlega málfræði X++ tungumálsins.

Hvernig á að túlka formlega BNF málfræði

Þessi hluti lýsir málfræði X++ í Backus Naur Form (BNF). Hér er lýst litlu dæmi um BNF.

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

AA er heiti framleiðslureglu. An AA krefst , BBfylgt eftir með CC_SYM. A BB er líka framleiðsluregla. Þess vegna, BB er ekki flugstöð. BB verður að vera annað hvort JJ_SYM eða KK_SYM. Bæði JJ_SYM og KK_SYM eru útstöðvar vegna þess að þær eru ekki nöfn annarra framleiðslureglna. CC_SYM er líka flugstöð.

Í BNF fyrir X++ málfræði hafa flestar útstöðvarnar _SYM sem viðskeyti nafns síns.

Formleg X++ málfræði í BNF

Þessi hluti inniheldur BNF sem skilgreinir málfræði 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

Frekari upplýsingar

X++ tungumálatilvísun