Cú pháp X++

Lưu ý

Các nhóm quan tâm cộng đồng hiện đã chuyển từ Yammer sang Microsoft Viva Engage. Để tham gia cộng đồng Viva Engage và tham gia vào các cuộc thảo luận mới nhất, hãy điền vào biểu mẫu Yêu cầu quyền truy cập vào Tài chính và Vận hành Viva Engage Community và chọn cộng đồng mà bạn muốn tham gia.

Bài viết này chứa tham chiếu cú pháp cho X++.

Từ khóa X++

Các từ khóa X++ được hiển thị trong bảng sau đây được dành riêng. Không thể sử dụng các từ khóa này cho bất kỳ mục đích nào khác.

Từ dành riêng Mô tả Thông tin liên quan
! Không. Toán tử Quan hệ
!= Toán tử bất bình đẳng (không bằng). Toán tử Quan hệ
# Tiền tố trên tên macro. Cách thực hiện: Sử #define và #if để Kiểm tra Macro
& Nhị phân AND. Toán tử số học
&& Lô-gic AND. Toán tử Quan hệ
( Toán tử gọi hàm, cho biết sự bắt đầu của cuộc gọi hàm.
) Toán tử gọi hàm, cho biết kết thúc cuộc gọi hàm.
* Nhân. Dấu sao () cũng* được dùng trong X++ SQL. Một cách sử dụng là biểu thị tất cả các trường từ các bảng trên một câu select lệnh. Một cách sử dụng khác là ký tự đại diện với toán like tử, biểu thị từ 0 đến nhiều ký tự theo bất kỳ kiểu nào. Toán like tử cũng sử dụng ký tự ?. Toán tử số học
^ XOR Nhị phân. Toán tử số học
| Nhị phân OR. Toán tử số học
|| Lô-gic OR. Toán tử Quan hệ
~ Không. Toán tử số học
+ Cộng. Toán tử số học
++ Tăng. Toán tử Gán
+= Phân công phụ gia. Toán tử Gán
, Toán tử dấu phẩy. Biểu thức được phân tách bởi dấu phẩy được đánh giá tuần tự từ trái sang phải.
- Trừ. Toán tử số học
-- Toán tử dấu giảm. Toán tử Gán
-= Nhiệm vụ phụ. Toán tử Gán
. Ví dụ: toán tử truy nhập thành viên lớp, formRun.run truy nhập run phương pháp của một đối tượng thuộc kiểu lớp FormRun.
/ Chia. Toán tử số học
\ Thoát trong xâu chuỗi. Thoát khỏi dấu ngoặc kép phụ và một số chữ cái nhất định như '\t' cho tab.
@ Thoát khỏi từ khóa. Ví dụ: var @str = 1@abstract; không biên dịch được mà không có @ ký tự khiến bất kỳ chuỗi nào theo sau nó được coi là mã định danh. Nó cũng ảnh hưởng đến chuỗi ký tự, bằng cách phủ định tác động của ký tự thoát \ và bằng cách cho phép chuỗi mở rộng nhiều hơn một dòng trong mã nguồn. Dòng mới được thể hiện bằng một ký tự số thập lục phân 0x0A, thường được gọi là nguồn cấp dòng. Không bao gồm ký tự dấu đầu dòng 0x0D thập lục phân, như trong 0x0D0A.
: Ký tự dấu hai chấm (:) được dùng để phân tách giá trị chữ hoa/thường trong câu switch lệnh.
:: Được sử dụng để gọi các phương pháp tĩnh (lớp): ClassName::methodName() và để chỉ định các ký tự liệt kê, chẳng hạn như NoYes::Yes.
; Chấm dứt câu lệnh. Được sử dụng for trong vòng lặp hoặc làm dấu tách các phần khởi tạo, cập nhật và kiểm tra giá trị.
< Nhỏ hơn. Toán tử Quan hệ
<< Dịch trái. Toán tử số học
<= Nhỏ hơn hoặc bằng. Toán tử số học
= Toán tử bài tập. Đối số ở bên trái của "=" được đặt thành giá trị của đối số ở bên phải. Toán tử Gán
== Trả về true nếu các biểu thức bằng nhau. Toán tử Quan hệ
> Lớn hơn. Toán tử Quan hệ
>= Lớn hơn hoặc bằng. Toán tử Quan hệ
>> Bitwise Phải Shift. Toán tử này dịch các bit ở bên tay trái theo số lượng ở bên tay phải. Mỗi shift chia một cách hiệu quả số cho 2^n, trong đó n là số vị trí được dịch chuyển. Toán tử số học
?: Toán tử thứ ba. Ký tự dấu chấm hỏi (?) cũng được toán tử sử dụng like để biểu thị chính xác một ký tự theo bất kỳ kiểu nào. Toán like tử cũng sử dụng ký tự. Toán tử Đại học (?)
[ Khai báo mảng, mở ra. Phải được sử dụng với "]".
] Bộ khai báo mảng, đóng lại. Phải được sử dụng với "[".
{ Bắt đầu một câu lệnh kết hợp có thể lần lượt chứa không hoặc nhiều câu lệnh. Câu lệnh kết hợp kết thúc bằng dấu khớp gần nhất "}".
} Cho biết phần cuối của câu lệnh kết hợp được mô tả ở trên. "{" phải xuất hiện trước câu lệnh đầu tiên trong các câu lệnh này.
trừu tượng Bổ trợ lớp và phương pháp. Một lớp trừu tượng không thể được xây dựng với từ khóa mới - Chỉ có các lớp bắt nguồn từ nó có thể. Không thể gọi ra một phương pháp trừu tượng, chỉ có những phương pháp ghi đè nó mới có thể được. Có thể sửa đổi bảng dưới dạng tóm tắt bằng cách đặt thuộc tính Trừu tượng của bảng thành Yes trong AOT hoặc bằng cách sử dụng DictTable lớp. Thuộc tính Trừu tượng mặc định là Không và không thể đặt trừ khi bảng khác mở rộng bảng. Mỗi hàng trong bảng tóm tắt phải có một hàng phụ thuộc trong bảng dẫn xuất. Điều này có nghĩa là mỗi hàng trong bảng trừu tượng có một giá trị lớn hơn không trong trường thuộc tính InstanceRelationType của nó. Không có hiệu ứng nào khác từ việc đánh dấu bảng là tóm tắt. Không chính thức, các lập trình viên thường sử dụng thuật ngữ cụ thể để mô tả một lớp học không trừu tượng. Tổng quan về Kế thừa Bảng của Bộ điều chỉnh Phương pháp
anytype Loại có thể chứa giá trị thuộc bất kỳ kiểu nào. Loại bất kỳ
như Cần thiết khi bạn gán biến lớp cơ sở cho biến lớp đã tạo ra. Ví dụ: với lớp Derived mở rộngBase lớp, myDerived = myBase as Derived; câu lệnh tránh lỗi trình biên dịch bằng cách sử dụng từ khóa làm từ khóa. Từ khóa này cũng áp dụng khi bạn gán biến bảng cơ sở cho biến bảng dẫn xuất. Nếu giá trị (myBase) không thuộc loại đã chỉ định (Dẫn xuất), biểu thức sẽ trả về null. Toán tử Biểu thức: Is and As for Inheritance
Asc Một tùy chọn trên mệnh orderby đề groupby or trong một câu select lệnh. Sắp xếp đang tăng dần. Cú pháp Chọn Câu lệnh
tại Xác định vị trí của cửa sổ in như một phần của câu lệnh print . Không nên sử dụng câu lệnh in. In Câu lệnh
Avg Trả về giá trị trung bình của các trường từ các hàng được xác định bởi mệnh group by đề trong một câu select lệnh. Cú pháp Chọn Câu lệnh
phá vỡ Thoát ngay lập tức khỏi khối mã lặp. Câu lệnh Ngắt
điểm dừng Đại diện cho điểm ngắt được đặt cho mục đích gỡ lỗi. Để đặt điểm ngắt trong mã của bạn, hãy viết: breakpoint;
bằng cách Một phần của thuật ngữ dành riêng, chẳng hạn như nhóm theo và sắp xếp theo.
byref Chỉ rõ rằng tham số đang được chuyển tới phương thức được gọi đang được chuyển qua bởi tham chiếu (địa chỉ), thay vì theo giá trị. Byref được dùng trong X++ khi gọi phương thức .NET lấy tham số theo tham số (chẳng hạn như từ khóa C# ra hoặc tham chiếu). Làm thế nào để: Sử dụng từ khóa byref cho CLR Interop.
trường hợp Lựa chọn trong một câu switch lệnh. Chuyển đổi Câu lệnh
bắt Được sử dụng trong xử lý ngoại lệ. Xử lý Ngoại lệ bằng cách thử và nắm bắt Từ khóa
changeCompany Thay đổi thiết đặt cơ sở dữ liệu thành công ty khác. Thay đổi Kiểu Thiết kế Công ty
lớp Khai báo lớp. Các lớp học trong X++
khách hàng Bộ điều chỉnh phương pháp. Những bổ trợ này không còn được sử dụng nữa. Tất cả các phương pháp được thực hiện trên tầng máy chủ. Bổ trợ Phương pháp
bình Chỉ định loại container . Các thùng chứa chứa một chuỗi các giá trị nguyên tử và các thùng chứa khác. Container
tiếp tục Bắt buộc lần lặp tiếp theo của một vòng lặp. Câu lệnh Tiếp tục
đếm Trả về số bản ghi từ các hàng được xác định bởi mệnh đề group by trong một câu select lệnh. Cú pháp Chọn Câu lệnh
crossCompany Đưa ra một select tuyên bố trả về dữ liệu cho tất cả các công ty mà người dùng được phép đọc từ đó. Thông tin cơ bản về Mã Chéo Công ty X++
ngày Xác định biến loại date. Ngày
mặc định Trường hợp mặc định trong switch các câu lệnh. Khối mã trong phần mặc định được thực thi nếu giá trị khóa chuyển không khớp với bất kỳ mệnh case đề nào được cung cấp trong câu lệnh switch . Chuyển đổi Câu lệnh
cử Một thành viên lớp học có thể lưu trữ nhiều tài liệu tham khảo đến các phương pháp trong các lớp học khác, và để gọi tất cả những phương pháp khi được nhắc để làm như vậy. Người đại diện có thể lưu trữ tham chiếu đến các loại phương pháp khác nhau bao gồm:
  • phương pháp tĩnh trên lớp X++
  • phương pháp phiên bản trên lớp X++
  • phương pháp trên các lớp .NET Framework
Thuật ngữ Sự kiện và Từ khóa X++, So sánh C#: Sự kiện
delete_from Cho phép bạn xóa bản ghi khỏi cơ sở dữ liệu. delete_from
mô tả Một tùy chọn trên mệnh order by đề group by or trong một câu select lệnh. Sắp xếp đang giảm dần. Cú pháp Chọn Câu lệnh
trưng bày Bộ điều chỉnh phương pháp. Phương pháp hiển< thị/> hiển thị được dùng để hiện các giá trị được tính toán trong điều khiển biểu mẫu. Không giống như các trường thông thường, các giá trị này không được lưu trữ trong cơ sở dữ liệu nhưng được tính toán tự động. Bổ trợ Phương pháp
Div Phép chia số nguyên. Toán tử số học
làm Bắt đầu vòng do...while lặp. Làm... trong khi Vòng lặp
biên tập Bộ điều chỉnh phương pháp. Phương edit pháp trong X++ cho phép người dùng sửa đổi giá trị trong điều khiển biểu mẫu trong khi thực thi lô-gic tùy chỉnh. Không giống display như các phương pháp, chỉ hiển thị các giá trị được tính, các phương pháp chỉnh sửa cho phép cả xem và chỉnh sửa. Bổ trợ Phương pháp
khác Thực hiện có điều kiện (if...else). Phần else của câu lệnh if được thực thi nếu biểu thức trong câu lệnh if được đánh giá là false nếu và nếu ... câu lệnh khác
eventHandler Phải được sử dụng mỗi lần bạn thêm hoặc xóa một tham chiếu phương pháp từ một đại diện bằng cách sử dụng toán += tử hoặc -= . Ví dụ: myDelegate += eventHandler(OtherClass::myStaticMethod); Thuật ngữ Sự kiện và Từ khóa X++, So sánh C#: Sự kiện
Tồn tại Được sử dụng join với mệnh đề trong select câu lệnh. Cú pháp Chọn Câu lệnh
Kéo dài Mệnh đề khai báo class hoặc interface. Nếu lớp của bạn không mở rộng lớp khác một cách rõ ràng, Object lớp của bạn sẽ được coi là mở rộng lớp (như thể bạn đã viết "mở rộng Đối tượng"). Tạo lớp con
SAI Chữ Boolean. Tiếng Booleans
cuối cùng Bổ trợ lớp và phương pháp. Xác định rằng không thể ghi đè phương pháp này. Bổ trợ Phương pháp
firstFast Được sử select dụng trong câu lệnh để tăng tốc độ tìm nạp cho hàng đầu tiên. Cú pháp Chọn Câu lệnh
thứ nhất Chỉ có Được sử dụng select trong các câu lệnh để chỉ tải bản ghi đầu tiên. Từ firstOnly khóa không đảm bảo rằng một câu lệnh SQL select sẽ truy xuất tối đa một bản ghi. Nếu AOS có thể sử dụng bộ đệm EntireTable ẩn để đáp ứng nhu cầu dữ liệu của câu select lệnh, từ khóa firstOnly sẽ bị bỏ qua. Chọn Bộ đệm ẩn dựa trên Cú pháp Câu lệnh
firstOnly10 Tương tự như firstOnly, ngoại trừ trả về 10 hàng thay vì một hàng.
firstOnly100 Giống như firstOnly, ngoại trừ trả về 100 hàng thay vì một hàng.
firstOnly1000 Giống như firstOnly, ngoại trừ trả về 1.000 hàng thay vì một hàng.
Flush Xóa toàn bộ bộ đệm ẩn bảng. Điều này có thể hữu ích khi bạn muốn đảm bảo rằng mọi thay đổi được thực hiện đối với bảng sẽ được phản ánh ngay lập tức trong các thao tác tiếp theo. Bộ đệm ẩn dựa trên bộ đặt
cho Cho lặp vòng lặp. Cho Vòng lặp
forceLiterals Được sử dụng select trong các câu lệnh để hiển thị các giá trị thực tế được sử where dụng trong mệnh đề với cơ sở dữ liệu Microsoft SQL Server tại thời điểm tối ưu hóa. Cú pháp Chọn Câu lệnh
forceNestedLoop Bắt buộc cơ sở dữ liệu SQL Server sử dụng thuật toán vòng lặp lồng nhau để xử lý một câu lệnh SQL cụ thể có chứa join. Cú pháp Chọn Câu lệnh
forcePlaceholders Được sử dụng select trong các câu lệnh where để hướng dẫn nhân không tiết lộ giá trị thực tế được sử dụng trong mệnh đề cho cơ sở dữ liệu Microsoft SQL Server tại thời điểm tối ưu hóa. Cú pháp Chọn Câu lệnh
forceSelectOrder Bắt buộc cơ sở dữ liệu SQL Server truy nhập các bảng theo kết nối theo thứ tự đã xác định. Cú pháp Chọn Câu lệnh
forUpdate Chọn các bản ghi dành riêng cho cập nhật. Thao tác sẽ được thực hiện trên các bản ghi được tải là một bản cập nhật. Tùy thuộc vào cơ sở dữ liệu cơ sở, các bản ghi có thể bị khóa đối với những người dùng khác. Cú pháp Chọn Câu lệnh
từ Một phần của tuyên select bố. Mệnh from đề xác định bộ đệm bảng trong đó các cột tồn tại. Cú pháp Chọn Câu lệnh
nhóm Một phần của mệnh group by đề trong một câu select lệnh. Cú pháp Chọn Câu lệnh
nếu Thực hiện có điều kiện. nếu và nếu ... câu lệnh khác
Thực hiện Thực hiện một interface. Tổng quan về Giao diện
insert_recordset Sao chép dữ liệu từ một hoặc nhiều bảng vào một bảng đích kết quả trong một chuyến đi máy chủ duy nhất. insert_recordset
Int Xác định biến loại integer (32 bit). Số nguyên
int64 Xác định biến loại integer (64 bit). Số nguyên
giao diện Khai báo giao diện. Tổng quan về Giao diện
Hỏi xem đối tượng được tham chiếu bởi một biến lớp hoặc kế thừa từ lớp nhất định hoặc là của lớp nhất định. Ví dụ: với lớp mở Derived rộng lớp học , biểu Base thức trả về (myDerived is Base)true. Từ khóa này áp dụng cho kế thừa lớp và kế thừa bảng. Toán tử Biểu thức: Is and As for Inheritance
nối Bảng được nối vào các cột chung cho cả hai bảng. Bạn có thể tạo một tập hợp kết quả duy nhất dựa trên nhiều bảng bằng cách sử dụng kết hợp. Cú pháp Chọn Câu lệnh
như Kiểm tra kết quả khớp theo mẫu hình, với ký hiệu ký tự đại diện '*' và '?'. Toán tử Quan hệ
maxof Trả về tối đa các trường từ các hàng được xác định bởi mệnh group by đề. Cú pháp Chọn Câu lệnh
tối thiểu Trả về tối thiểu các trường từ các hàng được xác định bởi mệnh group by đề. Cú pháp Chọn Câu lệnh
Mod Trả về số nguyên còn lại của biểu thức trái 1 chia cho biểu thức phải 2. Thông thường, điều này đôi khi được gọi là toán tử modulo. (12 mod 7) == 5 đúng.
mới Toán tử. Tạo một thể hiện của một lớp hoặc phân bổ bộ nhớ cho một mảng.
sau Tìm nạp bản ghi tiếp theo trong bảng hoặc gọi phương pháp tiếp theo theo chuỗi lệnh.
không tìm nạp Cho biết không có bản ghi nào sẽ được tải ngay bây giờ. Cú pháp Chọn Câu lệnh
notExists Được sử dụng join với mệnh đề trong select câu lệnh. Cú pháp Chọn Câu lệnh
không Hằng số biểu tượng.
lạc quanLock Bắt buộc một câu lệnh chạy với kiểm soát đồng thời lạc quan, ngay cả khi một giá trị khác được đặt trên bảng. Cú pháp Chọn Câu lệnh
đặt hàng Một phần của mệnh order by đề trong một câu select lệnh. Cú pháp Chọn Câu lệnh
Bên ngoài nối ngoài. Cú pháp Chọn Câu lệnh
Tạm dừng Dừng thực hiện công việc. Người dùng được yêu cầu nêu rõ có nên tiếp tục thực thi hay không. Bạn không nên sử dụng tuyên bố này trong mã sản xuất. Chọn Câu lệnh
bi quanLock Bắt buộc một câu lệnh để chạy với kiểm soát đồng thời bi quan, ngay cả khi một giá trị khác được đặt trên bảng. Cú pháp Chọn Câu lệnh
in Cho phép bạn hiển thị đầu ra trên màn hình. Bạn không nên sử dụng tuyên bố này trong mã sản xuất. In Câu lệnh
Bổ trợ truy nhập phương pháp. Phương pháp chỉ có thể được sử dụng trong lớp tuyên bố phương pháp. Điều khiển Truy nhập Phương pháp
Bảo vệ Bổ trợ truy nhập phương pháp. Phương pháp này có thể được sử dụng từ các phương pháp trong lớp tuyên bố các phương pháp, và trong bất kỳ lớp dẫn xuất. Điều khiển Truy nhập Phương pháp
công cộng Bổ trợ truy nhập phương pháp. Phương thức có thể được gọi từ bất kỳ lớp nào. Điều khiển Truy nhập Phương pháp
thực Chỉ định loại real , loại thập phân mà không làm tròn lỗi. Thực tế
repeatableRead Xác định rằng không có giao dịch nào khác có thể sửa đổi dữ liệu đã được đọc theo lô-gic bên trong giao dịch hiện tại, cho đến khi giao dịch hiện tại hoàn tất. Một giao dịch rõ ràng hoàn thành tại hoặc ttsAbort hoặc tại ngoài cùng ttsCommit. Đối với một câu lệnh chọn độc lập, thời lượng giao dịch là khoảng thời gian của lệnh chọn. Tuy nhiên, cơ sở dữ liệu đôi khi bắt buộc tương đương với repeatableRead trong câu lệnh chọn riêng lẻ ngay cả khi không có từ khóa này xuất hiện trong mã X++ của bạn (tùy thuộc vào cách cơ sở dữ liệu quyết định quét các bảng). Để biết thêm thông tin, hãy xem tài liệu dành cho sản phẩm cơ sở dữ liệu quan hệ cơ sở.
thử lại Được sử dụng trong xử lý ngoại lệ. Xử lý Ngoại lệ bằng cách thử và nắm bắt Từ khóa
về Trả về từ một phương thức. Khai báo phương pháp
Đảo ngược Các bản ghi được trả về theo thứ tự ngược lại. Cú pháp Chọn Câu lệnh
lựa Mệnh select đề chỉ định cột hoặc dạng xem nào được hiển thị trong tập kết quả. Chọn Câu lệnh
máy chủ Bộ điều chỉnh phương pháp. Bổ trợ này được bỏ qua và không nên được sử dụng, vì tất cả các phương pháp được thực hiện ở phía máy chủ. Bổ trợ Phương pháp
khung cảnh Được sử dụng với update_recordset lệnh. update_recordset
tĩnh Tĩnh phương pháp có thể không tham chiếu đến biến thể hiện (chỉ để tĩnh biến); có thể được gọi bằng cách sử dụng tên lớp chứ không phải trên phiên bản của lớp ("MyClass.aStaticProcedure"). Bổ trợ Phương pháp
Str Chỉ định loại string . Dây
tổng Trả về tổng của các trường từ các hàng được xác định bởi mệnh đề group by trong một câu select lệnh. Cú pháp Chọn Câu lệnh
siêu Gọi phương thức đã được ghi đè bằng phương pháp hiện tại. Phương pháp Bảng
Chuyển Câu lệnh Switch. Chuyển đổi Câu lệnh
tableLock Lỗi thời; tableLock không còn sẵn dùng.
này Tham chiếu đến thể hiện hiện tại của lớp. Được sử dụng trong mã X++ bên trong một phương pháp thể hiện của lớp. Được dùng để tham chiếu thành viên phương pháp của lớp.
ném Được sử dụng trong xử lý ngoại lệ. Xử lý Ngoại lệ bằng cách thử và nắm bắt Từ khóa
ĐÚNG VẬY Chữ Boolean. Tiếng Booleans
cố gắng Được sử dụng trong xử lý ngoại lệ. Xử lý Ngoại lệ bằng cách thử và nắm bắt Từ khóa
ttsAbort Quay lui (tức là bỏ) tất cả thay đổi trong giao dịch hiện tại. Tính toàn vẹn giao dịch
ttsBegin Đánh dấu sự bắt đầu của một giao dịch. Tính toàn vẹn giao dịch
ttsCommit Đánh dấu sự kết thúc của một giao dịch, cam kết những thay đổi cho các bảng. Tính toàn vẹn giao dịch
update_recordset Cho phép thao tác các tập hợp hàng trong một thao tác. update_recordset
validTimeState Lọc các hàng được truy xuất từ bảng trạng thái thời gian hợp lệ bằng câu lệnh SQL X+ select +. Ví dụ: chọn validTimeState(myDateEffective) * từ xMyTable; ... hoặc... chọn validTimeState(myDateFrom, myDateTo) * từ xMyTable; Ảnh hưởng của bảng trạng thái thời gian hợp lệ khi thao tác đọc và ghi
Void Xác định phương thức không trả về giá trị. Khai báo phương pháp
đâu Một phần của tuyên select bố. Mệnh where đề xác định các điều kiện cần thỏa mãn; nghĩa là, các hàng mà bạn muốn đưa vào kết quả. Cú pháp Chọn Câu lệnh
trong khi Câu lệnh thử lại. Thực thi một câu lệnh lặp đi lặp lại miễn là điều kiện kiểm tra là đúng. Trong khi vòng lặp trong khi chọn Câu lệnh
cửa sổ Cho phép bạn thay đổi kích thước của cửa sổ đầu ra. Được sử dụng với< báo cáo> in/in không được khuyến nghị trong mã sản xuất. In Câu lệnh

Cú pháp Biểu thức

Biểu thức trong X++ được sử dụng theo cách toán học hoặc lô-gic. Biểu thức được xây dựng trên các loại dữ liệu của ngôn ngữ; nghĩa là một biểu thức luôn trả về giá trị của một số loại. Giá trị này có thể được sử dụng trong tính toán, nhiệm vụ, câu lệnh có điều kiện, v.v.

Mô tả EBNF về biểu thức trong X++

Thuật ngữ   Định nghĩa
Expression = Biểu thức đơn giản [RelationalOperator Simple-expression ]
RelationalOperator = =
Biểu thức đơn giản = Biểu thức đơn giản [ +
Thuật ngữ = Compfactor { Mult-toán tử CompFactor }
Toán tử Mult = *
CompFactor = [ ! ] [ -
Yếu tố = Chữ
Enum = EnumName :: Theo nghĩa đen
Biến số = Mã định danh [ [ Biểu_thức ] ] [ . Biểu thức ]
FunctionCall = [ Biểu thức (.
Biểu thức if = Biểu thức? Biểu thức : Biểu thức

Các hạn chế ngữ pháp áp dụng trên cú pháp trước đó. Bạn không thể gọi bất kỳ phương thức nào bằng cách sử dụng toán tử :: . Tương tự, bạn không thể sử dụng từ khóa này mà không có đối tượng hiện hoạt; nghĩa là, nếu bạn không trong một phương pháp thể hiện và như vậy.

Ví dụ

Ví dụ về biểu thức Mô tả
1 Một ký tự số nguyên.
NoYes::No Tham chiếu liệt kê.
A Tham chiếu biến số.
Con nợ::Find("1") Một cuộc gọi phương pháp tĩnh (trả về một biến khách hàng).
(A > 3 ? true : false) Biểu thức if trả về true hoặc false.
(chọn CustTable nơi CustTable.Account == "100"). Vùng tên Biểu thức chọn. Trả về trường nameref trong bảng khách hàng. Đây là một chuỗi.
A >= B Một biểu thức lô-gic. Trả về true hoặc false.
A + B Một biểu thức số học. Tổng A và B.
A + B / C Tính toán B/C, sau đó thêm giá trị này vào A.
~ A + này. Giá trị() Tính tổng nhị phân không phải A và kết quả của giá trị gọi phương thức trên đối tượng trong phạm vi (điều này).
Con nợ::Tìm("1"). Vùng tên Trả về trường NameRef của bản ghi khách hàng đã tìm thấy.
Con nợ::Tìm("1"). Số dư() Một cuộc gọi phương thức Balance đến trong bảng khách hàng (Con nợ::Find trả về một khách hàng). Trả về số dư của khách hàng với tài khoản số 1.

Tổng quan về EBNF

Extended Backus Naur Form (EBNF) là một metalanguage và được sử dụng trong hướng dẫn này để mô tả cú pháp ngôn ngữ. Định nghĩa EBNF bao gồm các quy tắc sản xuất, các thiết bị đầu cuối và các thiết bị đầu cuối. Các thuật ngữ chính được hiển thị trong bảng sau đây.

Các thuật ngữ chính Ví dụ: Mô tả
Thiết bị đầu cuối Work_Team Thiết bị đầu cuối là một ký tự hoặc một chuỗi ký tự không bao giờ thay đổi.
Nonterminals Employee Một nonterminal là một mô tả một phần của một câu hợp lệ trong ngôn ngữ được xác định bởi một quy tắc sản xuất hoặc một mô tả văn bản. Một ký hiệu vô định luôn có thể được mở rộng đến một hoặc nhiều biểu tượng thiết bị đầu cuối.
Quy tắc sản xuất Nhân viên = Nhà phát triển Tester

Ví dụ:

Work_Team = Nhân viên Quản lý {, Nhân viên} Nhân viên = Nhà phát triển | Người kiểm tra Ví dụ này xác định Work_Team dạng như bao gồm một và Manager một hoặc nhiều Employees. An Employee được định nghĩa là Developer, hoặc Tester. Các ký hiệu được sử dụng trong ví dụ được mô tả trong bảng sau đây.

Các biểu tượng đặc biệt trong EBNF

Ký hiệu Mô tả
(Biểu thức) Dấu ngoặc đơn giữ các ký hiệu (thiết bị đầu cuối và dấu không xác định) với nhau. Họ có thể được đặt bất cứ nơi nào ở phía bên phải của quy tắc sản xuất.
Biểu thức 1 Biểu thức 2
[Biểu thức] Tùy chọn: Các mục giữa [ và ] là tùy chọn. Bao gồm tất cả hoặc không mục nào trong dấu ngoặc vuông.
{Expression} Lặp lại: Các mục giữa { và } là tùy chọn, nhưng có thể được lặp lại nhiều lần nếu cần.

Ví dụ: nếu các phụ kiện bạn mua cho xe đạp của mình bao gồm yên xe, giá giữ bình nước, chuông và sừng, bạn có thể có chuông hoặc sừng và không, một hoặc nhiều người giữ bình nước và chính xác một yên xe, điều này có thể được thể hiện là: Bicycle_Accessories = yên [bell | horn] {water_bottle_holders} Ngữ pháp này xác định các khả năng sau đây: saddlesaddle bellsaddle horn Yên water_bottle_holder chuông yên water_bottle_holder chuông yên water_bottle_holder water_bottle_holder và vân vân.

X++ Ngữ pháp

Bài viết này hiển thị ngữ pháp chính thức của ngôn ngữ X++.

Cách diễn giải ngữ pháp BNF Chính thức

Mục này mô tả ngữ pháp của X++ trong Biểu mẫu Backus Naur (BNF). Một ví dụ nhỏ về BNF được mô tả ở đây.

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

AA là tên của quy tắc sản xuất. An AA yêu cầu một BB, theo sau là một CC_SYM. A cũng BB là một quy tắc sản xuất. Vì vậy, BB không phải là một thiết bị đầu cuối. BB phải là một JJ_SYM hoặc một KK_SYM. Cả JJ_SYM và KK_SYM là thiết bị đầu cuối vì chúng không phải là tên của bất kỳ quy tắc sản xuất nào khác. CC_SYM cũng là một thiết bị đầu cuối.

Trong BNF cho X++ ngữ pháp, hầu hết các thiết bị đầu cuối _SYM là hậu tố của tên của họ.

Ngữ pháp X++ chính thức trong BNF

Phần này chứa BNF xác định ngữ pháp của 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

Tài nguyên khác

Tham chiếu Ngôn ngữ X++