إشعار
يتطلب الوصول إلى هذه الصفحة تخويلاً. يمكنك محاولة تسجيل الدخول أو تغيير الدلائل.
يتطلب الوصول إلى هذه الصفحة تخويلاً. يمكنك محاولة تغيير الدلائل.
إشعار
انتقلت مجموعات اهتمام المجتمع الآن من 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++، مقارنة 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