بناء الجملة X++

إشعار

انتقلت مجموعات اهتمام المجتمع الآن من Yammer إلى Microsoft Viva Engage. للانضمام إلى مجتمع Viva Engage والمشاركة في المناقشات الأخيرة، املأ نموذج طلب الوصول إلى Finance and Operations Viva Engage Community واختر المجتمع الذي تريد الانضمام إليه.

تحتوي هذه المقالة على مرجع بناء الجملة ل X++.

الكلمات الأساسية X++

الكلمات الأساسية X++ الموضحة في الجدول التالي محجوزة. لا يمكن استخدام هذه الكلمات الأساسية لأي غرض آخر.

كلمة محجوزة ‏‏الوصف‬ المعلومات ذات الصلة
! لا. عوامل التشغيل الارتباطية
!= عامل عدم المساواة (لا يساوي). عوامل التشغيل الارتباطية
# بادئة على أسماء الماكرو. كيفية: استخدام #define #if لاختبار ماكرو
& ثنائي و. عوامل التشغيل الحسابية
&& منطقي و. عوامل التشغيل الارتباطية
( عامل تشغيل استدعاء الدالة، الذي يشير إلى بداية استدعاء الدالة.
) عامل تشغيل استدعاء الدالة، الذي يشير إلى نهاية استدعاء الدالة.
* ضرب. تستخدم العلامة النجمية (*) أيضا في X++ SQL. أحد الاستخدامات هو الإشارة إلى كافة الحقول من الجداول على عبارة select . استخدام آخر هو كحرف بدل مع عامل التشغيل، للدلالة like على 0 إلى العديد من الأحرف من أي نوع. like يستخدم عامل التشغيل أيضا الحرف ؟ . عوامل التشغيل الحسابية
^ XOR ثنائي. عوامل التشغيل الحسابية
| ثنائي أو. عوامل التشغيل الحسابية
|| منطقي OR. عوامل التشغيل الارتباطية
~ لا. عوامل التشغيل الحسابية
+ زائد. عوامل التشغيل الحسابية
++ زياده. عوامل تشغيل التعيين
+= التعيين الإضافي. عوامل تشغيل التعيين
, عامل تشغيل الفاصلة. يتم تقييم التعبيرات المفصولة بفواصل بشكل تسلسلي من اليسار إلى اليمين.
- ناقص. عوامل التشغيل الحسابية
-- عامل تشغيل التناقص. عوامل تشغيل التعيين
-= التعيين الطرحي. عوامل تشغيل التعيين
. على سبيل المثال، formRun.run يصل عامل تشغيل الوصول إلى عضو الفئة إلى run أسلوب كائن من نوع FormRunالفئة .
/ تقسيم. عوامل التشغيل الحسابية
\ الهروب في سلاسل. إلغاء علامات اقتباس إضافية وأحرف معينة مثل '\t' لعلامة التبويب.
@ إلغاء الكلمات الأساسية. على سبيل المثال، var @str = 1@abstract; فشل التحويل البرمجي دون @ الحرف الذي يتسبب في اعتبار أي سلسلة تليه كمعرف. كما أنه يؤثر على السلاسل الحرفية، عن طريق نفي تأثير حرف \ escape، وعن طريق تمكين السلسلة لتمتد أكثر من سطر واحد في التعليمات البرمجية المصدر. يتم تمثيل السطر الجديد بحرف واحد من 0x0A سداسي عشري، والذي يسمى عادة موجز الأسطر. لا يتم تضمين حرف إرجاع حرف من 0x0D سداسي عشري، كما هو الحال في 0x0D0A.
: يتم استخدام حرف النقطين (:) لتحديد قيم حالة الأحرف في العبارة switch .
:: يستخدم لاستدعاء أساليب ثابتة (فئة): ClassName::methodName() وتعيين القيم الحرفية للتعداد، مثل NoYes::Yes.
; إنهاء العبارات. يستخدم في for التكرارات الحلقية أو كفاصل لأجزاء التهيئة والتحديث والتحقق من القيمة.
< اقل. عوامل التشغيل الارتباطية
<< التحول الأيسر. عوامل التشغيل الحسابية
<= أقل من أو يساوي. عوامل التشغيل الحسابية
= عامل تشغيل التعيين. يتم تعيين الوسيطة الموجودة على يسار "=" إلى قيمة الوسيطة إلى اليمين. عوامل تشغيل التعيين
== إرجاع true إذا كانت التعبيرات متساوية. عوامل التشغيل الارتباطية
> اكبر. عوامل التشغيل الارتباطية
>= أكبر من أو يساوي. عوامل التشغيل الارتباطية
>> Bitwise Right Shift. يقوم عامل التشغيل هذا بتحويل البتات في الجانب الأيسر بمقدار على الجانب الأيمن. يقسم كل تحول الرقم بشكل فعال على 2^n، حيث n هو عدد المواضع التي تم تغييرها. عوامل التشغيل الحسابية
?: عامل التشغيل الثلاثي. يستخدم عامل التشغيل أيضا حرف علامة الاستفهام (؟) للدلالة like على حرف واحد بالضبط من أي نوع. like يستخدم عامل التشغيل أيضا الحرف . عامل التشغيل الثلاثي (؟)
[ تعريف الصفيف، افتح. يجب استخدامه مع "]".
] إعلان الصفيف، إغلاق. يجب استخدامها مع "[".
{ يبدأ عبارة مركبة قد تحتوي بدورها على صفر أو أكثر من العبارات. تنتهي العبارة المركبة بأقرب مطابقة "}".
} يشير إلى نهاية العبارة المركبة الموضحة أعلاه. يجب أن يظهر "{" قبل أول هذه العبارات.
تجريدي معدل الفئة والأسلوب. لا يمكن إنشاء فئة مجردة باستخدام الكلمة الأساسية الجديدة - يمكن فقط للفئات المشتقة منها. لا يمكن استدعاء أسلوب مجرد ، بل يمكن فقط الأساليب التي تتجاوزه. يمكن تعديل الجدول على أنه مجرد عن طريق تعيين الخاصية Abstract الخاصة به إلى نعم في AOT، أو باستخدام DictTable الفئة . يتم تعيين الخاصية Abstract افتراضيا إلى لا، ولا يمكن تعيينها إلا إذا تم توسيع الجدول بواسطة جدول آخر. يجب أن يحتوي كل صف في جدول مجرد على صف تابع في جدول مشتق. وهذا يعني أن كل صف في جدول مجرد له قيمة أكبر من الصفر في حقل الخاصية InstanceRelationType الخاص به. لا توجد أي تأثيرات أخرى من وضع علامة على جدول على أنه مجرد. بشكل غير رسمي، غالبا ما يستخدم المبرمجون مصطلح الخرسانة لوصف فئة غير مجردة. نظرة عامة على توريث جدول معدلات الأسلوب
نوع أي نوع نوع يمكن أن يحتوي على قيم من أي نوع. نوع أي نوع
مثل مطلوب عند تعيين متغير فئة أساسية إلى متغير فئة مشتق. على سبيل المثال، نظرا لفئة DerivedتوسعBase فئة، تتجنب العبارة myDerived = myBase as Derived; خطأ المحول البرمجي باستخدام الكلمة الأساسية . تنطبق هذه الكلمة الأساسية أيضا عند تعيين متغير جدول أساسي إلى متغير جدول مشتق. إذا لم تكن القيمة (myBase) من النوع المعين (مشتق) فإن التعبير يرجع قيمة فارغة. عوامل تشغيل التعبير: Is و As for Inheritance
الرابطه خيار على orderby عبارة أو groupby في عبارة select . الفرز تصاعدي. تحديد بناء جملة
في تحديد موضع نافذة الطباعة كجزء من عبارة print . لا يجب استخدام عبارة الطباعة. طباعة العبارات
متوسط إرجاع متوسط الحقول من الصفوف المحددة بواسطة العبارة group by في عبارة select . تحديد بناء جملة
كسر الخروج الفوري من كتلة التعليمات البرمجية التكرارية. عبارات التوقف
نقطه يمثل نقطة توقف تم تعيينها لأغراض تصحيح الأخطاء. لتعيين نقطة توقف في التعليمات البرمجية الخاصة بك، اكتب: breakpoint;
ب جزء من مصطلح محجوز، مثل مجموعة حسب وترتيب حسب.
byref يحدد أن المعلمة التي يتم تمريرها إلى الأسلوب الذي يتم استدعاؤه يتم تمريرها حسب المرجع (العنوان)، بدلا من القيمة. يستخدم Byref في X++ عند استدعاء أسلوب .NET الذي يأخذ معلمة حسب المرجع (مثل الكلمات الأساسية C#‎ أوref). كيفية: استخدام الكلمة الأساسية byref ل CLR Interop.
حال التحديد ضمن عبارة switch . تبديل العبارات
القبض يستخدم في معالجة الاستثناء. معالجة الاستثناء مع المحاولة والتقاط الكلمات الأساسية
changeCompany تغيير إعدادات قاعدة البيانات إلى شركة أخرى. تغيير نمط تصميم الشركة
فصل يعلن عن فئة. الفئات في X++
عميل معدل الأسلوب. لم تعد هذه المعدلات تستخدم. يتم تنفيذ جميع الأساليب على مستوى الخادم. معدلات الأسلوب
وعاء container تعيين النوع. تحتوي الحاويات على تسلسل من القيم الذرية والحاويات الأخرى. الحاويات
استمر فرض التكرار التالي لحلقة. متابعة العبارات
عد إرجاع عدد السجلات من الصفوف المحددة بواسطة العبارة group by في عبارة select . تحديد بناء جملة
عبر الشركات يؤدي إلى إرجاع بيان select بيانات لجميع الشركات التي يصرح للمستخدم بالقراءة منها. أساسيات التعليمات البرمجية عبر الشركة X++
date تحديد متغير من النوع date. بلح
افتراضي الحالة الافتراضية داخل switch العبارات. يتم تنفيذ كتلة التعليمات البرمجية في الجزء الافتراضي إذا لم تتطابق قيمة التبديل مع أي من case العبارات المتوفرة في العبارة switch . تبديل العبارات
مندوب عضو فئة قادر على تخزين مراجع متعددة للأساليب في فئات أخرى، واستدعاء كافة هذه الأساليب عند مطالبتك بذلك. يمكن للمفوض تخزين المراجع إلى أنواع مختلفة من الأساليب بما في ذلك ما يلي:
  • أساليب ثابتة على فئات X++
  • أساليب المثيل في فئات X++
  • أساليب على فئات .NET Framework
مصطلحات الأحداث والكلمات الأساسية X++، مقارنة C#: حدث
delete_from يسمح لك بحذف السجلات من قاعدة البيانات. delete_from
تنازلي خيار على order by عبارة أو group by في عبارة select . الفرز تنازلي. تحديد بناء جملة
عرض معدل الأسلوب. يتم استخدام طريقة عرض</عرض> لإظهار القيم المحسوبة في عنصر تحكم النموذج. على عكس الحقول العادية، لا يتم تخزين هذه القيم في قاعدة البيانات ولكن يتم حسابها ديناميكيا. معدلات الأسلوب
div قسمة عدد صحيح. عوامل التشغيل الحسابية
فعل بداية التكرار do...while الحلقي. فعل... أثناء التكرار الحلقي
حرر معدل الأسلوب. edit يسمح الأسلوب في X++ للمستخدمين بتعديل القيم في عنصر تحكم النموذج أثناء تنفيذ منطق مخصص. على عكس display الأساليب، التي تعرض القيم المحسوبة فقط، تمكن أساليب التحرير كلا من العرض والتحرير. معدلات الأسلوب
وغير ذلك التنفيذ الشرطي (if...else). else يتم تنفيذ جزء العبارة if إذا تم تقييم التعبير في عبارة if إلىfalse إذا كان وإذا ... عبارات أخرى
eventHandler يجب استخدامها في كل مرة تقوم فيها بإضافة مرجع أسلوب أو حذفه من مفوض باستخدام += عامل التشغيل أو -= . على سبيل المثال: myDelegate += eventHandler(OtherClass::myStaticMethod); مصطلحات الأحداث والكلمات الأساسية X++، مقارنة C#: حدث
موجود يستخدم مع join العبارات في select العبارات. تحديد بناء جملة
يمتد عبارة تعريف فئة أو واجهة. إذا لم تقم الفئة بتوسيع فئة أخرى بشكل صريح، يتم اعتبار الفئة الخاصة بك لتوسيع Object الفئة (كما لو كنت قد كتبت "extends Object"). إنشاء فئة فرعية
خطأ قيمة منطقية حرفية. القيم المنطقية
نهائي معدل الفئة والأسلوب. يحدد أنه لا يمكن تجاوز هذا الأسلوب. معدلات الأسلوب
FirstFast يستخدم في select عبارات لتسريع إحضار الصف الأول. تحديد بناء جملة
أولا فقط يستخدم في select عبارات لجلب السجل الأول فقط. firstOnly لا تضمن الكلمة الأساسية استرداد سجل واحد كحد أقصى بواسطة عبارة X++ SQLselect. إذا كان بإمكان AOS استخدام EntireTable ذاكرة التخزين المؤقت لتلبية متطلبات البيانات الخاصة بالبيان select ، firstOnly يتم تجاهل الكلمة الأساسية . تحديد التخزين المؤقت المستند إلى مجموعة بناء جملة العبارة
firstOnly10 مثل firstOnly، باستثناء إرجاع 10 صفوف بدلا من صف واحد.
FirstOnly100 مثل firstOnly، باستثناء إرجاع 100 صف بدلا من صف واحد.
FirstOnly1000 مثل firstOnly، باستثناء إرجاع 1000 صف بدلا من صف واحد.
تدفق مسح ذاكرة التخزين المؤقت للجداول بأكملها. يمكن أن يكون هذا مفيدا عندما تريد التأكد من أن أي تغييرات تم إجراؤها على الجدول تنعكس على الفور في العمليات اللاحقة. التخزين المؤقت المستند إلى مجموعة
من أجل لتكرار التكرار الحلقي. بالنسبة إلى التكرارات الحلقية
forceLiterals يستخدم في select عبارات للكشف عن القيم الفعلية المستخدمة في where عبارات إلى قاعدة بيانات Microsoft SQL Server في وقت التحسين. تحديد بناء جملة
forceNestedLoop يفرض على قاعدة بيانات SQL Server استخدام خوارزمية حلقة متداخلة لمعالجة عبارة SQL معينة تحتوي على join. تحديد بناء جملة
فرض العناصر النائبة يستخدم في select عبارات لإرشاد kernel بعدم الكشف عن القيم الفعلية المستخدمة في where العبارات إلى قاعدة بيانات Microsoft SQL Server في وقت التحسين. تحديد بناء جملة
forceSelectOrder يفرض على قاعدة بيانات SQL Server الوصول إلى الجداول في صلة بالترتيب المحدد. تحديد بناء جملة
forUpdate تحديد السجلات للتحديث بشكل حصري. العملية التي سيتم تنفيذها على السجلات التي تم إحضارها هي تحديث. اعتمادا على قاعدة البيانات الأساسية، قد يتم تأمين السجلات للمستخدمين الآخرين. تحديد بناء جملة
من جزء من عبارة select . from تحدد العبارة المخزن المؤقت للجدول الذي توجد فيه الأعمدة. تحديد بناء جملة
مجموعة جزء من group by عبارة في عبارة select . تحديد بناء جملة
if التنفيذ الشرطي. إذا كان وإذا ... عبارات أخرى
تنفذ interfaceتنفيذ . نظرة عامة على الواجهات
insert_recordset نسخ البيانات من جدول واحد أو أكثر إلى جدول وجهة ناتج واحد في رحلة خادم واحدة. insert_recordset
int تحديد متغير من النوع integer (32 بت). الأعداد الصحيحة
int64 تحديد متغير من النوع integer (64 بت). الأعداد الصحيحة
واجهه تعريف الواجهة. نظرة عامة على الواجهات
هل يسأل ما إذا كان الكائن المشار إليه بواسطة متغير فئة إما يرث من الفئة المحددة أو من الفئة المحددة. على سبيل المثال، بالنظر إلى Derived فئة توسعBase فئة، يرجع التعبير (myDerived is Base)true. تنطبق هذه الكلمة الأساسية على توريث الفئة وتوارث الجدول. عوامل تشغيل التعبير: Is و As for Inheritance
join يتم ربط الجداول في أعمدة مشتركة بين الجدولين. يمكنك إنشاء مجموعة نتائج واحدة استنادا إلى جداول متعددة باستخدام الصلات. تحديد بناء جملة
مثل تختبر التطابقات حسب النمط، مع رموز أحرف البدل '*' و'؟'. عوامل التشغيل الارتباطية
الحد الأقصى إرجاع الحد الأقصى للحالحقول من الصفوف المحددة بواسطة العبارة group by . تحديد بناء جملة
الحد الأدنى إرجاع الحد الأدنى من الحقول من الصفوف المحددة بواسطة العبارة group by . تحديد بناء جملة
mod إرجاع العدد الصحيح المتبقي من التعبير الأيسر1 مقسوما على التعبير الأيمن2. بشكل غير رسمي يسمى هذا أحيانا عامل تشغيل وحدة نمطية. (12 mod 7) == 5 صحيح.
الجديد المشغل. إنشاء مثيل لفئة أو تخصيص ذاكرة لصفيف.
مقبل إحضار السجل التالي في جدول أو استدعاء الأسلوب التالي في تسلسل سلسلة الأوامر.
noFetch يشير إلى أنه لا توجد سجلات ليتم إحضارها الآن. تحديد بناء جملة
notExists يستخدم مع join العبارات في select العبارات. تحديد بناء جملة
صِفْر ثابت رمزي.
تفاؤللوك يفرض تشغيل عبارة مع التحكم المتفائل في التزامن، حتى إذا تم تعيين قيمة مختلفة على الجدول. تحديد بناء جملة
ترتيب جزء من order by عبارة في عبارة select . تحديد بناء جملة
خارجي صلة خارجية. تحديد بناء جملة
تورع يوقف تنفيذ وظيفة. يطلب من المستخدم تحديد ما إذا كان يجب متابعة التنفيذ. يجب عدم استخدام هذه العبارة في التعليمات البرمجية للإنتاج. تحديد عبارات
قفل متشائم يفرض تشغيل عبارة مع عنصر تحكم التزامن المتشائم، حتى إذا تم تعيين قيمة مختلفة على الجدول. تحديد بناء جملة
طبع يسمح لك بعرض الإخراج على الشاشة. يجب عدم استخدام هذه العبارة في التعليمات البرمجية للإنتاج. طباعة العبارات
عسكري معدل الوصول إلى الأسلوب. يمكن استخدام الأسلوب فقط داخل الفئة التي تعلن عن الأسلوب. التحكم في الوصول إلى الأسلوب
محمي معدل الوصول إلى الأسلوب. يمكن استخدام الأسلوب من الأساليب في الفئة التي تعلن عن الأساليب، وفي أي فئات مشتقة. التحكم في الوصول إلى الأسلوب
عام معدل الوصول إلى الأسلوب. يمكن استدعاء الأسلوب من أي فئة. التحكم في الوصول إلى الأسلوب
real real تعيين النوع، وهو نوع عشري دون تقريب الأخطاء. الحقيقيه
قراءة قابلة للتكرار يحدد أنه لا يمكن لأي معاملات أخرى تعديل البيانات التي تمت قراءتها حسب المنطق داخل المعاملة الحالية، حتى بعد اكتمال المعاملة الحالية. تكتمل المعاملة الصريحة إما في ttsAbort أو في أقصى ttsCommit. بالنسبة لبيان تحديد مستقل، تكون مدة المعاملة هي مدة أمر التحديد . ومع ذلك، تفرض قاعدة البيانات أحيانا ما يعادل repeatableRead في عبارات تحديد فردية حتى دون ظهور هذه الكلمة الأساسية في التعليمات البرمجية X++ (اعتمادا على كيفية قرار قاعدة البيانات بفحص الجداول). لمزيد من المعلومات، راجع وثائق منتج قاعدة البيانات الارتباطية الأساسية.
اعاده المحاوله يستخدم في معالجة الاستثناء. معالجة الاستثناء مع المحاولة والتقاط الكلمات الأساسية
أعاد إرجاع من أسلوب. إعلان الأساليب
reverse يتم إرجاع السجلات بترتيب عكسي. تحديد بناء جملة
اختار select تحدد العبارة الأعمدة أو طرق العرض المعروضة في مجموعة النتائج. تحديد عبارات
ملقم معدل الأسلوب. يتم تجاهل هذا المعدل ولا يجب استخدامه، حيث يتم تنفيذ كافة الأساليب على جانب الخادم. معدلات الأسلوب
اعداد يستخدم مع الأمر update_recordset . update_recordset
ثابتة قد لا تشير الأساليب الثابتة إلى متغيرات المثيل (فقط إلى المتغيرات الثابتة)؛ يمكن استدعاء باستخدام اسم الفئة بدلا من مثيل للفئة ("MyClass.aStaticProcedure"). معدلات الأسلوب
شارع string تعيين النوع. السلاسل
مجموع إرجاع مجموع الحقول من الصفوف المحددة بواسطة العبارة group by في عبارة select . تحديد بناء جملة
عملاق استدعاء الأسلوب الذي تم تجاوزه بواسطة الأسلوب الحالي. أساليب الجدول
حول تبديل العبارة. تبديل العبارات
tableLock عفا عليها الزمن; لم يعد tableLock متوفرا.
هذا مرجع إلى المثيل الحالي للفئة. يستخدم في التعليمات البرمجية X++ داخل أسلوب مثيل للفئة. يستخدم للإشارة إلى أعضاء الأسلوب للفئة.
رمى يستخدم في معالجة الاستثناء. معالجة الاستثناء مع المحاولة والتقاط الكلمات الأساسية
صحيح قيمة منطقية حرفية. القيم المنطقية
حاول يستخدم في معالجة الاستثناء. معالجة الاستثناء مع المحاولة والتقاط الكلمات الأساسية
ttsAbort العودة إلى الحالة السابقة (أي تجاهل) جميع التغييرات في المعاملة الحالية. تكامل المعاملات
ttsBegin وضع علامة على بداية المعاملة. تكامل المعاملات
ttsCommit يضع علامة على نهاية المعاملة، مع تنفيذ التغييرات على الجداول. تكامل المعاملات
update_recordset يسمح بمعالجة مجموعات الصفوف ضمن عملية واحدة. update_recordset
حالة الوقت الصالحة تصفية الصفوف التي يتم استردادها من جدول حالة زمنية صالح بواسطة عبارة X++ SQL select . على سبيل المثال: حدد validTimeState(myDateEffective) * من xMyTable; ... أو... حدد validTimeState(myDateFrom, myDateTo) * من xMyTable; تأثيرات جداول الحالة الزمنية الصالحة على عمليات القراءة والكتابة
خلاء تعريف أسلوب لا يرجع قيمة. إعلان الأساليب
أين جزء من عبارة select . where تحدد العبارة الشروط التي يجب استيفاءها؛ أي الصفوف التي تريد تضمينها في النتيجة. تحديد بناء جملة
بينما عبارة التكرار. تنفيذ عبارة بشكل متكرر طالما أن شرط الاختبار صحيح. أثناء التكرار الحلقي أثناء تحديد عبارات
نافذة يسمح لك بتغيير حجم نافذة الإخراج. يستخدم مع عبارات الطباعة</الطباعة> غير الموصى بها في التعليمات البرمجية للإنتاج. طباعة العبارات

بناء جملة التعبيرات

يتم استخدام تعبير في X++ إما بطريقة رياضية أو منطقية. التعبيرات مبنية على أنواع بيانات اللغة؛ أي أن التعبير يقوم دائما بإرجاع قيمة من نوع ما. يمكن استخدام هذه القيمة في العمليات الحسابية والتعيينات والعبارات الشرطية وما إلى ذلك.

وصف EBNF للتعبيرات في X++

Term   التعريف
Expression = تعبير بسيط [RelationalOperator Simple-expression ]
تشغيل علائقي = =
تعبير بسيط = تعبير بسيط [ +
Term = Compfactor { Mult-operator CompFactor }
عامل تشغيل Mult = *
CompFactor = [ ! ] [ -
عامل = حرفي
التعداد = EnumName :: القيمة الحرفية
عامل = المعرف [ [ تعبير ] ] [ . Expression ]
FunctionCall = [ تعبير (.
تعبير إذا = تعبير؟ تعبير : تعبير

تنطبق القيود الدلالية على بناء الجملة السابق. لا يمكنك استدعاء أي أسلوب باستخدام عامل التشغيل :: . وبالمثل، لا يمكنك استخدام هذه الكلمة الأساسية دون كائن نشط؛ أي إذا لم تكن ضمن أسلوب مثيل وهكذا.

أمثلة

مثال على التعبير ‏‏الوصف‬
1 عدد صحيح حرفي.
NoYes::No مرجع تعداد.
A مرجع متغير.
المدين::بحث("1") استدعاء أسلوب ثابت (إرجاع متغير عميل).
(A > 3 ? true : false) تعبير if الذي يرجع صوابا أو خطأ.
(حدد CustTable حيث CustTable.Account == "100"). NameRef تعبير تحديد. إرجاع حقل nameref في جدول العميل. هذه سلسلة.
A >= B تعبير منطقي. إرجاع صواب أو خطأ.
A + B تعبير حسابي. جمع A وB.
A + B / C حساب B/C، ثم إضافة هذا إلى A.
~A + هذا. القيمة() جمع ثنائي وليس A ونتيجة قيمة استدعاء الأسلوب على الكائن في النطاق (هذا).
المدين::بحث("1"). NameRef إرجاع الحقل NameRef لسجل العميل الذي تم العثور عليه.
المدين::بحث("1"). الرصيد() استدعاء أسلوب إلى Balance في جدول العميل (المدين::البحث يرجع عميلا). إرجاع رصيد العميل برقم الحساب 1.

نظرة عامة على EBNF

نموذج Backus Naur الموسع (EBNF) عبارة عن مجموعة معدنية ويستخدم في هذا الدليل لوصف بناء جملة اللغة. يتكون تعريف EBNF من قواعد الإنتاج، وغير النهائية، والمحطات الطرفية. يتم عرض المصطلحات الرئيسية في الجدول التالي.

المصطلحات الأساسية مثال ‏‏الوصف‬
محطات Work_Team المحطة الطرفية هي حرف واحد أو سلسلة من الأحرف التي لا تتغير أبدا.
غير محددة Employee غير محدد هو وصف لجزء من جملة صالحة باللغة التي يتم تعريفها إما بواسطة قاعدة إنتاج أو وصف نصي. يمكن دائما توسيع الرمز غير الدائم إلى رمز طرفي واحد أو أكثر.
قواعد الإنتاج الموظف = المطور اختبار

مثال

Work_Team = موظف المدير {، الموظف} الموظف = المطور | Tester يعرف هذا المثال Work_Team على أنه يتكون من Manager و واحد أو أكثر Employees. Employee يتم تعريف على أنه Developer، أو Tester. يتم وصف الرموز المستخدمة في المثال في الجدول التالي.

رموز خاصة في EBNF

الرمز ‏‏الوصف‬
(تعبير) تحتفظ الأقواس بالرموز (المحطات الطرفية وغير النهائية) معا. يمكن وضعها في أي مكان على الجانب الأيمن من قاعدة الإنتاج.
Expression1 Expression2
[تعبير] اختياري: العناصر بين [و] اختيارية. يتم تضمين كل العناصر الموجودة بين الأقواس أو لا يتم تضمينها.
{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 هو اسم قاعدة الإنتاج. AA يتطلب ، BBمتبوعا CC_SYM. A 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++