Nóta
Aðgangur að þessari síðu krefst heimildar. Þú getur prófað aðskrá þig inn eða breyta skráasöfnum.
Aðgangur að þessari síðu krefst heimildar. Þú getur prófað að breyta skráasöfnum.
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:
|
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