Κοινοποίηση μέσω


Σύνταξη X++

Note

Οι ομάδες ενδιαφέροντος της κοινότητας έχουν πλέον μετακινηθεί από το Yammer στο Microsoft Viva Engage. Για να συμμετάσχετε σε μια κοινότητα Viva Engage και να συμμετάσχετε στις τελευταίες συζητήσεις, συμπληρώστε τη φόρμα Αίτηση πρόσβασης στο Finance and Operations Viva Engage Community και επιλέξτε την κοινότητα στην οποία θέλετε να συμμετάσχετε.

Αυτό το άρθρο περιέχει την αναφορά σύνταξης για X++.

X++ Λέξεις-κλειδιά

Οι λέξεις-κλειδιά X++ που εμφανίζονται στον παρακάτω πίνακα είναι δεσμευμένες. Αυτές οι λέξεις-κλειδιά δεν μπορούν να χρησιμοποιηθούν για οποιονδήποτε άλλο σκοπό.

Δεσμευμένη λέξη Περιγραφή Σχετικές πληροφορίες
! Όχι. Σχεσιακοί τελεστές
!= Τελεστής ανισότητας (όχι ίσος με). Σχεσιακοί τελεστές
# Πρόθεμα σε ονόματα μακροεντολών. Τρόπος: Χρήση #define και #if για τη δοκιμή μιας μακροεντολής
& Δυαδικό AND. Αριθμητικοί τελεστές
&& Λογικό AND. Σχεσιακοί τελεστές
( Τελεστής κλήσης συνάρτησης, ο οποίος υποδεικνύει την αρχή της κλήσης συνάρτησης.
) Τελεστής κλήσης συνάρτησης, ο οποίος υποδεικνύει το τέλος της κλήσης συνάρτησης.
* Πολλαπλασιάζω. Ο αστερίσκος (*) χρησιμοποιείται επίσης στην SQL X++. Μία χρήση είναι η υπογραφή όλων των πεδίων από τους πίνακες σε μια select πρόταση. Μια άλλη χρήση είναι ως χαρακτήρας μπαλαντέρ με τον like τελεστή , για να δηλώσει 0 σε πολλούς χαρακτήρες οποιουδήποτε είδους. Ο like τελεστής χρησιμοποιεί επίσης τον χαρακτήρα ? . Αριθμητικοί τελεστές
^ Δυαδική XOR. Αριθμητικοί τελεστές
| Δυαδικό OR. Αριθμητικοί τελεστές
|| Λογικό OR. Σχεσιακοί τελεστές
~ Όχι. Αριθμητικοί τελεστές
+ Συν. Αριθμητικοί τελεστές
++ Αύξηση. Τελεστές ανάθεσης
+= Προσθετική ανάθεση. Τελεστές ανάθεσης
, Τελεστής κόμμα. Οι παραστάσεις που διαχωρίζονται με κόμματα αξιολογούνται διαδοχικά από αριστερά προς τα δεξιά.
- Μείον. Αριθμητικοί τελεστές
-- Τελεστής προσαύξησης. Τελεστές ανάθεσης
-= Ανάθεση αφαίρεσης. Τελεστές ανάθεσης
. Ο τελεστής πρόσβασης μέλους κλάσης, για παράδειγμα, formRun.run αποκτά πρόσβαση στη run μέθοδο ενός αντικειμένου τύπου FormRunκλάσης .
/ Διαιρώ. Αριθμητικοί τελεστές
\ Διαφυγή σε συμβολοσειρές. Διαφεύγει με επιπλέον εισαγωγικά και ορισμένα γράμματα όπως "\t" για το tab.
@ Διαφυγή λέξεων-κλειδιών. Για παράδειγμα, var @str = 1@abstract; αποτυγχάνει η μεταγλώττιση χωρίς το @ χαρακτήρα που προκαλεί τη δημιουργία συμβολοσειράς που ακολουθεί, ώστε να θεωρηθεί ως αναγνωριστικό. Επηρεάζει επίσης τις συμβολοσειρές λεκτικής σταθεράς, ακυώνοντας το αποτέλεσμα του χαρακτήρα διαφυγής \ και ενεργοποιώντας τη συμβολοσειρά ώστε να εκτείνεται σε περισσότερες από μία γραμμές στον πηγαίο κώδικα. Η νέα γραμμή αντιπροσωπεύεται από έναν χαρακτήρα δεκαεξαδικής 0x0A, η οποία συνήθως ονομάζεται αλλαγή γραμμής. Δεν περιλαμβάνεται χαρακτήρας αλλαγής παραγράφου δεκαεξαδικής 0x0D, όπως σε 0x0D0A.
: Ο χαρακτήρας άνω και κάτω τελείας (:) χρησιμοποιείται για τον οριοθέτηση τιμών πεζών-κεφαλαίων στην switch πρόταση.
:: Χρησιμοποιείται για την κλήση στατικών μεθόδων (κλάσης): ClassName::methodName() και για τον καθορισμό λεκτικών σταθερών απαρίθμησης, όπως NoYes::Ναι.
; Τερματίζει προτάσεις. Χρησιμοποιείται σε for βρόχους ή ως διαχωριστικό των τμημάτων προετοιμασίας, ενημέρωσης και ελέγχου τιμών.
< Λιγότερο από. Σχεσιακοί τελεστές
<< Αριστερή μετατόπιση. Αριθμητικοί τελεστές
<= Μικρότερο από ή ίσο με. Αριθμητικοί τελεστές
= Τελεστής ανάθεσης. Το όρισμα αριστερά του "=" ορίζεται στην τιμή του ορίσματος στα δεξιά. Τελεστές ανάθεσης
== Επιστρέφει true εάν οι παραστάσεις είναι ίσες. Σχεσιακοί τελεστές
> Μεγαλύτερο από. Σχεσιακοί τελεστές
>= Μεγαλύτερο από ή ίσο με. Σχεσιακοί τελεστές
>> Bitwise Right Shift. Αυτός ο τελεστής μετατοπίζει bit στην αριστερή πλευρά κατά την ποσότητα στη δεξιά πλευρά. Κάθε μετατόπιση διαιρεί αποτελεσματικά τον αριθμό με το 2^n, όπου n είναι ο αριθμός των θέσεων που μετατοπίζονται. Αριθμητικοί τελεστές
?: Ternary τελεστής. Ο χαρακτήρας ερωτηματικού (?) χρησιμοποιείται επίσης από τον like τελεστή για να δηλώσει ακριβώς έναν χαρακτήρα οποιουδήποτε είδους. Ο like τελεστής χρησιμοποιεί επίσης τον χαρακτήρα . Ternary Operator (?)
[ Δηλωτής πίνακα, ανοίξτε. Πρέπει να χρησιμοποιείται με "]".
] Δηλωτής πίνακα, κλείσιμο. Πρέπει να χρησιμοποιείται με το "[".
{ Ξεκινά μια σύνθετη πρόταση που μπορεί με τη σειρά της να περιέχει μηδέν ή περισσότερες προτάσεις. Η σύνθετη πρόταση τελειώνει με το πλησιέστερο αντίστοιχο "}".
} Υποδεικνύει το τέλος της σύνθετης πρότασης που περιγράφεται παραπάνω. Πρέπει να εμφανιστεί ένα "{" πριν από την πρώτη από αυτές τις προτάσεις.
αφηρημένος Τροποποιητής κλάσης και μεθόδου. Μια αφηρημένη κλάση δεν μπορεί να δημιουργηθεί με τη νέα λέξη-κλειδί - Μόνο οι που προέρχονται από αυτήν μπορούν. Μια αφηρημένη μέθοδος δεν μπορεί να κληθεί, μόνο οι μέθοδοι που την παρακάμπτουν μπορούν. Ένας πίνακας μπορεί να τροποποιηθεί ως αφηρημένος ορίζοντας την ιδιότητά του Abstract σε Yes στον AOT ή χρησιμοποιώντας την DictTable κλάση . Η ιδιότητα Abstract λαμβάνει από προεπιλογή την τιμή Όχι και δεν μπορεί να οριστεί εκτός εάν ο πίνακας επεκταθεί από έναν άλλο πίνακα. Κάθε γραμμή σε έναν αφηρημένο πίνακα πρέπει να έχει μια εξαρτώμενη γραμμή σε έναν παραγόμενο πίνακα. Αυτό σημαίνει ότι κάθε γραμμή σε έναν αφηρημένο πίνακα έχει μια τιμή μεγαλύτερη του μηδενός στο πεδίο ιδιότητας InstanceRelationType . Δεν υπάρχουν άλλα εφέ από τη σήμανση ενός πίνακα ως αφηρημένου. Ανεπίσημα, οι προγραμματιστές συχνά χρησιμοποιούν τον όρο συγκεκριμένο για να περιγράψουν μια κλάση που δεν είναι αφηρημένη. Επισκόπηση μεταβίβασης πίνακα τροποποιητών μεθόδου
anytype Ένας τύπος που μπορεί να περιέχει τιμές οποιουδήποτε τύπου. Anytype
όπως Απαιτείται όταν αναθέτετε μια μεταβλητή βασικής κλάσης σε μια παραγόμενη μεταβλητή κλάσης. Για παράδειγμα, με βάση μια Derived κλάση που επεκτείνει μια Base κλάση, η πρόταση myDerived = myBase as Derived; αποφεύγει ένα σφάλμα μεταγλωττιστή χρησιμοποιώντας τη λέξη-κλειδί ως λέξη-κλειδί. Αυτή η λέξη-κλειδί ισχύει επίσης όταν αντιστοιχίζετε μια μεταβλητή βασικού πίνακα σε μια παραγόμενη μεταβλητή πίνακα. Εάν η τιμή (myBase) δεν είναι του καθορισμένου τύπου (Παραγόμενο), η παράσταση επιστρέφει τιμή null. Τελεστές παράστασης: Is και As για μεταβίβαση
asc Μια επιλογή στον orderby όρο or groupby σε μια select πρόταση. Η ταξινόμηση είναι αύξουσα. Επιλογή σύνταξης πρότασης
σε Καθορίζει τη θέση ενός παραθύρου εκτύπωσης ως μέρος μιας print πρότασης. Η πρόταση εκτύπωσης δεν πρέπει να χρησιμοποιείται. Προτάσεις εκτύπωσης
μέσος όρος Επιστρέφει τον μέσο όρο των πεδίων από τις γραμμές που καθορίζονται από τον group by όρο σε μια select πρόταση. Επιλογή σύνταξης πρότασης
σπάζω Άμεση έξοδος από ένα επαναληπτικό μπλοκ κώδικα. Προτάσεις διακοπής
σημείο διακοπής Αντιπροσωπεύει ένα σημείο διακοπής που έχει οριστεί για σκοπούς εντοπισμού σφαλμάτων. Για να ορίσετε ένα σημείο διακοπής στον κείμενό σας, γράψτε: breakpoint;
διά Μέρος ενός δεσμευμένου όρου, όπως ομαδοποίηση κατά και παραγγελία κατά.
byref Καθορίζει ότι η παράμετρος που διαβιβάζεται στην ονομάζεται μέθοδος διαβιβάζεται μέσω αναφοράς (διεύθυνσης), αντί κατά τιμή. Το Byref χρησιμοποιείται σε X++ κατά την κλήση μιας μεθόδου .NET που λαμβάνει μια παράμετρο μέσω αναφοράς (όπως με τις λέξεις-κλειδιά C# εκτός ή ref). Πώς να: Χρησιμοποιήστε τη λέξη-κλειδί byref για CLR Interop.
υπόθεση Επιλογή μέσα σε μια switch πρόταση. Εναλλαγή καταστάσεων
πιάνω Χρησιμοποιείται στον χειρισμό εξαιρέσεων. Χειρισμός εξαιρέσεων με try και αλίευση λέξεων-κλειδιών
αλλαγήΕταιρική Αλλάζει τις ρυθμίσεις βάσης δεδομένων σε μια άλλη εταιρεία. Αλλαγή μοτίβου σχεδίασης εταιρείας
κλάση Δηλώνει μια κλάση. σε X++
πελάτης Τροποποιητής μεθόδου. Αυτοί οι τροποποιητές δεν χρησιμοποιούνται πλέον. Όλες οι μέθοδοι εκτελούνται στο επίπεδο διακομιστή. Τροποποιητές μεθόδου
δοχείο Προσδιορίζει τον container τύπο. Τα κοντέινερ περιέχουν μια ακολουθία ατομικών τιμών και άλλων κοντέινερ. Δοχεία
συνεχίζω Επιβάλλει την επόμενη επανάληψη ενός βρόχου. Συνέχεια δηλώσεων
μετρώ Επιστρέφει τον αριθμό εγγραφών από τις γραμμές που καθορίζονται από τον group by όρο σε μια select πρόταση. Επιλογή σύνταξης πρότασης
crossCompany Προκαλεί μια select πρόταση επιστροφής δεδομένων για όλες τις εταιρείες από τις οποίες έχει εξουσιοδοτηθεί να διαβάσει ο χρήστης. Βασικά στοιχεία κώδικα X++ μεταξύ εταιρειών
ημερομηνία Καθορίζει μια μεταβλητή τύπου date. Ημερομηνίες
προεπιλογή Προεπιλεγμένη υπόθεση μέσα σε switch προτάσεις. Το μπλοκ κώδικα στο προεπιλεγμένο τμήμα εκτελείται εάν η τιμή διακόπτη δεν συμφωνεί με οποιονδήποτε από case τους όρους που παρέχονται στην switch πρόταση. Εναλλαγή καταστάσεων
αντιπρόσωπος Ένα μέλος κλάσης που μπορεί να αποθηκεύσει πολλές αναφορές σε μεθόδους σε άλλες και να καλέσει όλες αυτές τις μεθόδους όταν του ζητηθεί. Μια παραπομπή μπορεί να αποθηκεύσει αναφορές σε διάφορα είδη μεθόδων, συμπεριλαμβανομένων των εξής:
  • στατικές μέθοδοι σε X++
  • μέθοδοι παρουσίας σε X++
  • μέθοδοι σε .NET Framework
Ορολογία συμβάντων και Λέξεις-κλειδιά X++, Σύγκριση C#: Συμβάν
delete_from Σας επιτρέπει να διαγράψετε εγγραφές από τη βάση δεδομένων. delete_from
desc Μια επιλογή στον order by όρο or group by σε μια select πρόταση. Η ταξινόμηση είναι φθίνουσα. Επιλογή σύνταξης πρότασης
εκθέτω Τροποποιητής μεθόδου. Χρησιμοποιείται μια μέθοδος εμφάνισης</εμφάνισης> για την εμφάνιση υπολογιζόμενων τιμών σε ένα στοιχείο ελέγχου φόρμας. Σε αντίθεση με τα κανονικά πεδία, αυτές οι τιμές δεν αποθηκεύονται στη βάση δεδομένων, αλλά υπολογίζονται δυναμικά. Τροποποιητές μεθόδου
div Διαίρεση ακέραιων. Αριθμητικοί τελεστές
κάνω Αρχή ενός do...while βρόχου. Κάνω... ενώ οι βρόχοι
επεξεργασία Τροποποιητής μεθόδου. Μια edit μέθοδος στο X++ επιτρέπει στους χρήστες να τροποποιούν τιμές σε ένα στοιχείο ελέγχου φόρμας κατά την εκτέλεση προσαρμοσμένης λογικής. Σε αντίθεση με display τις μεθόδους, οι οποίες εμφανίζουν μόνο υπολογιζόμενες τιμές, οι μέθοδοι επεξεργασίας επιτρέπουν την προβολή και επεξεργασία. Τροποποιητές μεθόδου
άλλος Εκτέλεση υπό όρους (if...else). Το else τμήμα της πρότασης if εκτελείται εάν η παράσταση στην πρόταση if αξιολογείται σε false if και if ... προτάσεις else
eventHandler Πρέπει να χρησιμοποιείται κάθε φορά που προσθέτετε ή διαγράφετε μια αναφορά μεθόδου από μια παραπομπή, χρησιμοποιώντας τον += τελεστή ή -= . Για παράδειγμα: myDelegate += eventHandler(OtherClass::myStaticMethod); Ορολογία συμβάντων και Λέξεις-κλειδιά X++, Σύγκριση C#: Συμβάν
Υπάρχει Χρησιμοποιείται με join όρους σε select προτάσεις. Επιλογή σύνταξης πρότασης
Επεκτείνει Ένας όρος δήλωσης κλάσης ή διασύνδεσης. Εάν η κλάση σας δεν επεκτείνει ρητά μια άλλη κλάση, η κλάση σας θεωρείται ότι επεκτείνει την Object κλάση (σαν να είχατε γράψει "επεκτείνει το αντικείμενο"). Δημιουργία δευτερεύουσας κλάσης
ψεύτικος Δυαδική λεκτική σταθερά. Δυαδικές τιμές
τελικός Τροποποιητής κλάσης και μεθόδου. Καθορίζει ότι δεν είναι δυνατή η παράκαμψη αυτής της μεθόδου. Τροποποιητές μεθόδου
firstFast Χρησιμοποιείται σε select προτάσεις για την επιτάχυνση της ανάκτησης για την πρώτη γραμμή. Επιλογή σύνταξης πρότασης
firstOnly Χρησιμοποιείται σε select προτάσεις για τη λήψη μόνο της πρώτης εγγραφής. Η firstOnly λέξη-κλειδί δεν εγγυάται ότι ανακτάται το πολύ μία εγγραφή από μια πρόταση SQL select X++. Εάν το AOS μπορεί να χρησιμοποιήσει το EntireTable cache για να ικανοποιήσει τις απαιτήσεις δεδομένων της select πρότασης, η firstOnly λέξη-κλειδί παραβλέπεται. Επιλέξτε Σύνταξη πρότασης Προσωρινή αποθήκευση βάσει συνόλου
firstOnly10 Όμοια με το firstOnly, η εκτός από την επιστρέφει 10 γραμμές αντί για μία.
firstOnly100 Όμοια με το firstOnly, η εκτός από την επιστρέφει 100 γραμμές αντί για μία.
firstOnly1000 Ίδια με την firstOnly, η εκτός από την επιστρέφει 1.000 γραμμές αντί για μία.
εξάπτομαι Διαγράφει ολόκληρο το cache πίνακα. Αυτό μπορεί να είναι χρήσιμο όταν θέλετε να εξασφαλίσετε ότι τυχόν αλλαγές που έγιναν στον πίνακα αντικατοπτρίζονται αμέσως στις επόμενες λειτουργίες. Προσωρινή αποθήκευση βάσει συνόλου
για Για επανάληψη βρόχου. Για βρόχους
forceLiterals Χρησιμοποιούνται σε select προτάσεις για την αποκάλυψη πραγματικών τιμών που χρησιμοποιούνται σε where όρους στη βάση δεδομένων Microsoft SQL Server κατά τη στιγμή της βελτιστοποίησης. Επιλογή σύνταξης πρότασης
forceNestedLoop Επιβάλλει στη βάση δεδομένων SQL Server να χρησιμοποιήσει έναν αλγόριθμο ένθετης βρόχου για την επεξεργασία μιας συγκεκριμένης πρότασης SQL που περιέχει μια join. Επιλογή σύνταξης πρότασης
forcePlaceholders Χρησιμοποιείται σε select προτάσεις για να καθοδηγήσει τον πυρήνα να μην αποκαλύψει τις πραγματικές τιμές που χρησιμοποιούνται σε όρους στη where βάση δεδομένων Microsoft SQL Server κατά τη στιγμή της βελτιστοποίησης. Επιλογή σύνταξης πρότασης
forceSelectOrder Επιβάλλει στη βάση δεδομένων SQL Server να αποκτήσει πρόσβαση στους πίνακες με μια ένωση με την καθορισμένη σειρά. Επιλογή σύνταξης πρότασης
forUpdate Επιλέγει εγγραφές αποκλειστικά για ενημέρωση. Η λειτουργία που θα εκτελεστεί στις εγγραφές που θα ανακτούν είναι μια ενημέρωση. Ανάλογα με την υποκείμενη βάση δεδομένων, οι εγγραφές μπορεί να κλειδωθούν για άλλους χρήστες. Επιλογή σύνταξης πρότασης
από Μέρος μιας δήλωσης select . Ο from όρος καθορίζει το buffer πίνακα στον οποίο υπάρχουν οι στήλες. Επιλογή σύνταξης πρότασης
ομάδα Μέρος του όρου group by σε μια select δήλωση. Επιλογή σύνταξης πρότασης
if Εκτέλεση υπό όρους. if και if ... προτάσεις else
Υλοποιεί Υλοποίηση ενός interface. Επισκόπηση διασυνδέσεων
insert_recordset Αντιγράφει δεδομένα από έναν ή περισσότερους πίνακες σε έναν πίνακα προορισμού που προκύπτει σε μία μόνο διαδρομή διακομιστή. insert_recordset
int Καθορίζει μια μεταβλητή τύπου integer (32 bit). Ακέραιοι
int64 Καθορίζει μια μεταβλητή τύπου integer (64 bit). Ακέραιοι
διεπαφή Δήλωση διασύνδεσης. Επισκόπηση διασυνδέσεων
Είναι Ρωτά εάν το αντικείμενο στο οποίο γίνεται αναφορά από μια μεταβλητή κλάσης είτε λαμβάνει την τιμή από τη δεδομένη κλάση είτε είναι της δεδομένης κλάσης. Για παράδειγμα, με βάση μια Derived κλάση που επεκτείνει μια Base κλάση, η παράσταση (myDerived is Base) επιστρέφει την τιμή true. Αυτή η λέξη-κλειδί ισχύει για τη μεταβίβαση κλάσης και τη μεταβίβαση πίνακα. Τελεστές παράστασης: Is και As για μεταβίβαση
join Οι πίνακες ενώνονται σε στήλες κοινές και στους δύο πίνακες. Μπορείτε να δημιουργήσετε ένα μοναδικό σύνολο αποτελεσμάτων με βάση πολλούς πίνακες, χρησιμοποιώντας συνδέσμους. Επιλογή σύνταξης πρότασης
αγαπώ Ελέγχει για αντιστοιχίσεις κατά μοτίβο, με σύμβολα μπαλαντέρ "*" και "?". Σχεσιακοί τελεστές
μέγιστη τιμή Επιστρέφει το μέγιστο από τα πεδία από τις γραμμές που καθορίζονται από τον group by όρο . Επιλογή σύνταξης πρότασης
minof Επιστρέφει το ελάχιστο από τα πεδία από τις γραμμές που καθορίζονται από τον group by όρο . Επιλογή σύνταξης πρότασης
mod Επιστρέφει το υπόλοιπο ακέραιου της αριστερής παράστασης1 διά της δεξιάς παράστασης2. Ανεπίσημα, αυτό ορισμένες φορές ονομάζεται τελεστής modulo. (12 mod 7) == 5 είναι αλήθεια.
νέος Χειριστής. Δημιουργεί μια παρουσία μιας κλάσης ή εκχωρεί μνήμη για έναν πίνακα.
επόμενος Ανακτά την επόμενη εγγραφή σε έναν πίνακα ή καλεί την επόμενη μέθοδο με μια αλληλουχία εντολών.
noFetch Υποδεικνύει ότι δεν θα ληφθούν εγγραφές τώρα. Επιλογή σύνταξης πρότασης
notExists Χρησιμοποιείται με join όρους σε select προτάσεις. Επιλογή σύνταξης πρότασης
null Συμβολική σταθερά.
αισιόδοξος αποκλεισμός Επιβάλλει μια πρόταση να εκτελεστεί με αισιόδοξο στοιχείο ελέγχου ταυτόχρονης εκτέλεσης, ακόμα και αν έχει οριστεί διαφορετική τιμή στον πίνακα. Επιλογή σύνταξης πρότασης
παραγγελία Μέρος του όρου order by σε μια select δήλωση. Επιλογή σύνταξης πρότασης
εξωτερικός εξωτερικό σύνδεσμο. Επιλογή σύνταξης πρότασης
παύση Διακόπτει την εκτέλεση μιας εργασίας. Ζητείται από το χρήστη να δηλώσει εάν πρέπει να συνεχιστεί η εκτέλεση. Δεν πρέπει να χρησιμοποιείτε αυτήν την πρόταση σε κώδικα παραγωγής. Επιλογή πρότασης
απαισιόδοξος Αποκλεισμός Επιβάλλει μια πρόταση να εκτελεστεί με απαισιόδοξο στοιχείο ελέγχου ταυτόχρονης εκτέλεσης, ακόμα και αν έχει οριστεί διαφορετική τιμή στον πίνακα. Επιλογή σύνταξης πρότασης
τυπώνω Σας επιτρέπει να εμφανίσετε την έξοδο στην οθόνη. Δεν πρέπει να χρησιμοποιείτε αυτήν την πρόταση σε κώδικα παραγωγής. Προτάσεις εκτύπωσης
ιδιωτικός Τροποποιητής πρόσβασης μεθόδου. Η μέθοδος μπορεί να χρησιμοποιηθεί μόνο εντός της κλάσης που δηλώνει τη μέθοδο. Έλεγχος πρόσβασης μεθόδου
Προστατεύεται Τροποποιητής πρόσβασης μεθόδου. Η μέθοδος μπορεί να χρησιμοποιηθεί από μεθόδους στην κλάση που δηλώνει τις μεθόδους και σε οποιεσδήποτε παραγόμενες. Έλεγχος πρόσβασης μεθόδου
δημόσιος Τροποποιητής πρόσβασης μεθόδου. Η μέθοδος μπορεί να κληθεί από οποιαδήποτε κλάση. Έλεγχος πρόσβασης μεθόδου
πραγματικός Ορίζει τον real τύπο, έναν δεκαδικό τύπο χωρίς σφάλματα στρογγυλοποίησης. Πραγματικά
repeatableRead Καθορίζει ότι καμία άλλη συναλλαγή δεν μπορεί να τροποποιήσει δεδομένα που έχουν διαβαστεί από λογική εντός της τρέχουσας συναλλαγής, μέχρι να ολοκληρωθεί η τρέχουσα συναλλαγή. Μια ρητή συναλλαγή ολοκληρώνεται είτε στο ttsAbort είτε στο εξωτερικό ttsCommit. Για μια αυτόνομη πρόταση επιλογής , η διάρκεια συναλλαγής είναι η διάρκεια της εντολής επιλογής . Ωστόσο, η βάση δεδομένων μερικές φορές επιβάλλει το ισοδύναμο του repeatableRead σε μεμονωμένες προτάσεις επιλογής ακόμη και χωρίς να εμφανίζεται αυτή η λέξη-κλειδί στον κώδικά σας X++ (ανάλογα με τον τρόπο με τον οποίο η βάση δεδομένων αποφασίζει να σαρώσει τους πίνακες). Για περισσότερες πληροφορίες, ανατρέξτε στην τεκμηρίωση για το υποκείμενο προϊόν σχεσιακής βάσης δεδομένων.
Επανάληψη Χρησιμοποιείται στον χειρισμό εξαιρέσεων. Χειρισμός εξαιρέσεων με try και αλίευση λέξεων-κλειδιών
επιστροφή Επιστρέφει από μια μέθοδο. Δήλωση μεθόδων
αντίστροφος Οι εγγραφές επιστρέφονται με αντίστροφη σειρά. Επιλογή σύνταξης πρότασης
διαλέγω Ο select όρος ορίζει ποιες στήλες ή προβολές εμφανίζονται στο σύνολο αποτελεσμάτων. Επιλογή πρότασης
διακομιστής Τροποποιητής μεθόδου. Αυτός ο τροποποιητής παραβλέπεται και δεν πρέπει να χρησιμοποιείται, καθώς όλες οι μέθοδοι εκτελούνται στην πλευρά του διακομιστή. Τροποποιητές μεθόδου
ρύθμιση Χρησιμοποιείται με την εντολή update_recordset . update_recordset
στατικός Οι στατικές μέθοδοι δεν μπορούν να αναφέρονται σε μεταβλητές παρουσίας (μόνο σε στατικές μεταβλητές). το μπορεί να κληθεί χρησιμοποιώντας το όνομα κλάσης αντί σε μια παρουσία της κλάσης ("MyClass.aStaticProcedure"). Τροποποιητές μεθόδου
str Προσδιορίζει τον string τύπο. Συμβολοσειρές
άθροισμα Επιστρέφει το άθροισμα των πεδίων από τις γραμμές που καθορίζονται από τον group by όρο σε μια select πρόταση. Επιλογή σύνταξης πρότασης
έξοχος Καλεί τη μέθοδο που παρακάμπτεται από την τρέχουσα μέθοδο. Μέθοδοι πίνακα
διακόπτης Αλλαγή πρότασης. Εναλλαγή καταστάσεων
tableLock Απαρχαιωμένος; Το tableLock δεν είναι πλέον διαθέσιμο.
αυτό Μια αναφορά στην τρέχουσα παρουσία της κλάσης. Χρησιμοποιείται σε κώδικα X++ μέσα σε μια μέθοδο παρουσίας της κλάσης. Χρησιμοποιείται για αναφορά μελών μεθόδου της κλάσης.
ρίχνω Χρησιμοποιείται στον χειρισμό εξαιρέσεων. Χειρισμός εξαιρέσεων με try και αλίευση λέξεων-κλειδιών
πιστός Δυαδική λεκτική σταθερά. Δυαδικές τιμές
δοκιμάζω Χρησιμοποιείται στον χειρισμό εξαιρέσεων. Χειρισμός εξαιρέσεων με try και αλίευση λέξεων-κλειδιών
ttsAbort Επαναφορά (δηλαδή απόρριψη) όλων των αλλαγών στην τρέχουσα συναλλαγή. Ακεραιότητα συναλλαγών
ttsBegin Σηματοδοτεί την αρχή μιας συναλλαγής. Ακεραιότητα συναλλαγών
ttsCommit Επισημαίνει το τέλος μιας συναλλαγής, δεσμεύοντας τις αλλαγές στους πίνακες. Ακεραιότητα συναλλαγών
update_recordset Επιτρέπει τον χειρισμό συνόλων γραμμών μέσα σε μία λειτουργία. update_recordset
validTimeState Φιλτράρει τις γραμμές που ανακτώνται από έναν έγκυρο πίνακα κατάστασης ώρας με μια πρόταση SQL select X++. Για παράδειγμα: επιλέξτε validTimeState(myDateEffective) * από xMyTable; ... ή... επιλέξτε validTimeState(myDateFrom, myDateTo) * από xMyTable; Αποτελέσματα έγκυρων πινάκων κατάστασης ώρας σε λειτουργίες ανάγνωσης και εγγραφής
κενό Προσδιορίζει μια μέθοδο που δεν επιστρέφει μια τιμή. Δήλωση μεθόδων
πού Μέρος μιας δήλωσης select . Ο where όρος καθορίζει τις συνθήκες που θα ικανοποιηθούν, δηλαδή, τις γραμμές που θέλετε να συμπεριληφθούν στο αποτέλεσμα. Επιλογή σύνταξης πρότασης
ενώ Δήλωση επανάληψης. Εκτελεί μια δήλωση επανειλημμένα εφόσον η συνθήκη δοκιμής είναι αληθής. Ενώ οι βρόχοι όταν επιλέγετε Προτάσεις
παράθυρο Σας επιτρέπει να αλλάξετε το μέγεθος του παραθύρου εξόδου. Χρησιμοποιείται με προτάσεις εκτύπωσης</εκτύπωσης> που δεν συνιστώνται σε κώδικα παραγωγής. Προτάσεις εκτύπωσης

Σύνταξη παραστάσεων

Μια παράσταση σε X++ χρησιμοποιείται είτε με μαθηματικό είτε με λογικό τρόπο. Οι παραστάσεις βασίζονται στους τύπους δεδομένων της γλώσσας. δηλαδή, μια παράσταση επιστρέφει πάντα μια τιμή κάποιου τύπου. Αυτή η τιμή μπορεί να χρησιμοποιηθεί σε υπολογισμούς, αναθέσεις, προτάσεις υπό όρους και ούτω καθεξής.

Περιγραφή παραστάσεων EBNF σε X++

Όρος   Ορισμός
Παράσταση = Απλή-παράσταση [RelationalOperator Απλή-παράσταση ]
Σχεσιακός έλεγχος = =
Απλή παράσταση = Απλή-παράσταση [ +
Όρος = Compfactor { Mult-τελεστής CompFactor }
Τελεστής Mult = *
CompFactor = [ ! ] [ -
Παράγοντας = Κυριολεκτικός
Απαρίθμηση = EnumName :: Λεκτική σταθερά
Μεταβλητή = Αναγνωριστικό [ [ Παράσταση ] ] [ . Παράσταση ]
FunctionCall = [ Παράσταση (.
Παράσταση-If = Έκφραση? Παράσταση : Παράσταση

Ισχύουν σημασιολογικοί περιορισμοί στην προηγούμενη σύνταξη. Δεν μπορείτε να καλέσετε καμία μέθοδο χρησιμοποιώντας τον τελεστή :: Παρομοίως, δεν μπορείτε να χρησιμοποιήσετε αυτή τη λέξη-κλειδί χωρίς ενεργό αντικείμενο. Δηλαδή, εάν δεν είστε εντός μιας μεθόδου παρουσίας και ούτω καθεξής.

Παραδείγματα

Παράδειγμα παράστασης Περιγραφή
1 Μια λεκτική σταθερά ακέραιου.
NoYes::Όχι Μια αναφορά απαρίθμησης.
A Μια αναφορά-μεταβλητής.
Οφειλέτης::Find("1") Μια στατική κλήση-μεθόδου (επιστρέφει μια μεταβλητή πελάτη).
(A > 3 ? true : false) Μια παράσταση-if που επιστρέφει true ή false.
(επιλέξτε CustTable όπου CustTable.Account == "100"). NameRef Μια παράσταση-επιλογής. Επιστρέφει το πεδίο nameref στον πίνακα πελάτη. Αυτή είναι μια συμβολοσειρά.
A >= B Μια λογική παράσταση. Επιστρέφει true ή false.
A + B Μια αριθμητική παράσταση. Αθροίσματα A και B.
A + B / C Υπολογίζει το B/C και, στη συνέχεια, το προσθέτει στο A.
~A + αυτό. Value() Αθροίζει το δυαδικό not A και το αποτέλεσμα της μεθόδου-κλήσης Τιμή στο αντικείμενο εντός εμβέλειας (αυτό).
Οφειλέτης::Find("1"). NameRef Επιστρέφει το πεδίο NameRef της εγγραφής πελάτη που βρέθηκε.
Οφειλέτης::Find("1"). Υπόλοιπο() Μια κλήση μεθόδου προς Balance στον πίνακα πελάτη (Οφειλέτης::Η Εύρεση επιστρέφει έναν πελάτη). Επιστρέφει το υπόλοιπο του πελάτη με αριθμό λογαριασμού 1.

Επισκόπηση EBNF

Το Extended Backus Naur Form (EBNF) είναι ένα metalanguage και χρησιμοποιείται σε αυτόν τον οδηγό για να περιγράψει τη σύνταξη της γλώσσας. Ένας ορισμός EBNF αποτελείται από κανόνες παραγωγής, μη τερματικούς σταθμούς και τερματικούς σταθμούς. Οι βασικοί όροι εμφανίζονται στον παρακάτω πίνακα.

Βασικοί όροι Παράδειγμα Περιγραφή
Τερματικά Work_Team Ένα τερματικό είναι ένας χαρακτήρας ή μια συμβολοσειρά χαρακτήρων που δεν αλλάζουν ποτέ.
Μη εταιρικά στοιχεία Employee Μια μηminal είναι μια περιγραφή μέρους μιας έγκυρης πρότασης στη γλώσσα που ορίζεται είτε από έναν κανόνα παραγωγής είτε από μια περιγραφή κειμένου. Ένα μη καθορισμένο σύμβολο μπορεί πάντα να επεκταθεί σε ένα ή περισσότερα σύμβολα τερματικού.
Κανόνες παραγωγής Employee = Developer Δοκιμαστής

Παράδειγμα

Work_Team = Διευθυντής Υπάλληλος {, Υπάλληλος} Υπάλληλος = Προγραμματιστής | Tester Αυτό το παράδειγμα ορίζει μια Work_Team που αποτελείται από ένα Manager και ένα ή περισσότερα Employees. Η συνάρτηση An Employee ορίζεται ως , Developerή Tester. Τα σύμβολα που χρησιμοποιούνται στο παράδειγμα περιγράφονται στον παρακάτω πίνακα.

Ειδικά σύμβολα στο EBNF

Σύμβολο Περιγραφή
(Παράσταση) Οι παρενθέσεις κρατούν τα σύμβολα (τερματικά και μη τερματικά) μαζί. Μπορούν να τοποθετηθούν οπουδήποτε στη δεξιά πλευρά ενός κανόνα παραγωγής.
Παράσταση1 Παράσταση2
[Παράσταση] Προαιρετικό: Τα στοιχεία μεταξύ [ και ] είναι προαιρετικά. Περιλαμβάνονται όλα ή κανένα από τα στοιχεία στις αγκύλες.
{Expression} Επανάληψη: Τα στοιχεία μεταξύ { και } είναι προαιρετικά, αλλά μπορούν να επαναληφθούν όσες φορές χρειαστεί.

Για παράδειγμα, αν τα αξεσουάρ που αγοράζετε για το ποδήλατό σας αποτελούνται από σέλα, κατόχους μπουκαλιών νερού, καμπάνες και κέρατα και θα μπορούσατε να έχετε είτε ένα κουδούνι είτε ένα κέρατο και μηδέν, έναν ή περισσότερους κατόχους μπουκαλιών νερού και ακριβώς μία σέλα, αυτό θα μπορούσε να εκφραστεί ως: Bicycle_Accessories = σέλα [κουδούνι | κέρας] {water_bottle_holders} Αυτή η γραμματική ορίζει τις ακόλουθες δυνατότητες: saddlesaddle bellsaddle horn σέλα water_bottle_holder κουδούνι σέλας water_bottle_holder καμπάνα σέλας water_bottle_holder water_bottle_holder Και ούτω καθεξής.

Γραμματική X++

Αυτό το άρθρο δείχνει την επίσημη γραμματική της γλώσσας X++.

Πώς να ερμηνεύσετε την επίσημη γραμματική BNF

Αυτή η ενότητα περιγράφει τη γραμματική του X++ στη φόρμα Backus Naur (BNF). Ένα μικρό παράδειγμα BNF περιγράφεται εδώ.

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

AA Το είναι το όνομα ενός κανόνα παραγωγής. Η συνάρτηση An AA απαιτεί μια BB, ακολουθούμενη από μια CC_SYM. Το Α BB είναι επίσης ένας κανόνας παραγωγής. Επομένως, BB το δεν είναι τερματικό. BB Το πρέπει να είναι είτε JJ_SYM, είτε KK_SYM. Τόσο οι JJ_SYM όσο και οι KK_SYM είναι τερματικά επειδή δεν είναι τα ονόματα οποιωνδήποτε άλλων κανόνων παραγωγής. CC_SYM είναι επίσης τερματικό.

Στη γραμματική BNF για X++, τα περισσότερα τερματικά έχουν _SYM ως επίθημα του ονόματός τους.

Επίσημη γραμματική X++ στο BNF

Αυτή η ενότητα περιέχει το BNF που ορίζει τη γραμματική του 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

Πρόσθετοι πόροι

Αναφορά γλώσσας X++