Phiên bản được hỗ trợ:hiện tại(17) /16 / 15 / 14 / 13
Phiên bản phát triển:18 / Devel
Phiên bản không được hỗ trợ:12 / 11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0 / 7.4 / 7.3 / 7.2 / 7.1
Tài liệu này dành cho phiên bản không được hỗ trợ của PostgreSQL.
Bạn có thể muốn xem cùng một trang chohiện tại9599_9680

44.3. Giai đoạn kèo bóng đá kèo bóng đá pháp

TheGiai đoạn kèo bóng đá phápbao gồm hai Phần:

  • Thekèo bóng đá phápđược xác định tronggram.yScan.lđược xây dựng bằng Công cụ UNIXBisonFlex.

  • TheQuy trình chuyển đổikhông sửa đổi và tăng cường cho các cấu trúc dữ liệu được trả về bởi trình kèo bóng đá pháp.

44.3.1. Trình kèo bóng đá pháp

Trình kèo bóng đá pháp phải kiểm tra chuỗi truy vấn (đến Văn bản ASCII đơn giản) cho cú pháp hợp lệ. Nếu cú ​​pháp đúng aparse Treeđược xây dựng và trao tay mặt sau; nếu không một lỗi được trả về. Trình kèo bóng đá pháp và lexer là được triển khai bằng công cụ UNIX nổi tiếngBisonFlex.

TheLexerđược xác định trong tệpScan.Lvà chịu trách nhiệm cho nhận dạngĐịnh danh, TheTừ khóa SQLvv. Cho mọi từ khóa hoặc Định danh được tìm thấy, Amã thông báoIS được tạo và bàn giao cho trình kèo bóng đá pháp.

Trình kèo bóng đá pháp được xác định trong tệpgram.y12231_12259Quy tắc ngữ kèo bóng đá phápActionđược thực thi bất cứ khi nào một quy tắc sa thải. Mã của các hành động (thực sự là mã c) là được sử dụng để xây dựng cây kèo bóng đá pháp.

TệpScan.lđược chuyển đổi thành Tệp nguồn CScan.cSử dụng chương trìnhFlexgram.yđược chuyển đổi thànhgram.cSử dụngBison. Sau khi những biến đổi này có Có thể sử dụng trình biên dịch C bình thường để tạo trình kèo bóng đá pháp. Không bao giờ thực hiện bất kỳ thay đổi nào đối với các tệp C được tạo vì chúng sẽ được ghi đè vào lần tớiFlexhoặcBisonđược gọi.

Lưu ý:Các biến đổi được đề cập và Các phần tổng hợp thường được thực hiện tự động bằng cách sử dụngMakefilesĐược vận chuyển vớiPostgreSQLNguồn kèo bóng đá pháp bổ.

Một mô tả chi tiết vềBisonhoặc các quy tắc ngữ kèo bóng đá pháp được đưa ra tronggram.ysẽ vượt quá phạm vi của Bài viết này. Có nhiều sách và tài liệu liên quan đếnFlexBison. Bạn nên quen thuộc vớiBisonTrước khi bạn bắt đầu Nghiên cứu ngữ kèo bóng đá pháp được đưa ra tronggram.yNếu không bạn sẽ không hiểu điều gì xảy ra ở đó.

14107_14143

Giai đoạn kèo bóng đá pháp tạo một cây phân tích chỉ bằng cách sử dụng các quy tắc cố định về cấu trúc cú pháp của SQL. Nó không làm cho bất kỳ tra cứu trong các danh mục hệ thống, do đó không có khả năng Hiểu các ngữ nghĩa chi tiết của các hoạt động được yêu cầu. Sau khi trình kèo bóng đá pháp hoàn thành,Quy trình chuyển đổiĐưa cây thuận tay trở lại bởi trình kèo bóng đá pháp làm đầu vào và thực hiện ngữ nghĩa cần giải thích để hiểu bảng, chức năng nào, và các nhà khai thác được tham chiếu bởi truy vấn. Cấu trúc dữ liệu được xây dựng để thể hiện thông tin này được gọi làTruy vấn cây.

Lý do tách kèo bóng đá pháp thô khỏi kèo bóng đá pháp ngữ nghĩa Có thể thực hiện tra cứu danh mục hệ thống chỉ có thể được thực hiện trong giao dịch và chúng tôi không muốn bắt đầu một giao dịch Ngay lập tức khi nhận được một chuỗi truy vấn. kèo bóng đá pháp thô giai đoạn là đủ để xác định kiểm soát giao dịch lệnh (Bắt đầu, rollback, v.v.), và sau đó có thể được chính xác thực hiện mà không có bất kỳ kèo bóng đá pháp thêm. Một khi chúng ta biết rằng chúng ta đang xử lý một truy vấn thực tế (chẳng hạn nhưChọnhoặcCập nhật), nó Có thể bắt đầu một giao dịch nếu chúng tôi chưa có. Chỉ sau đó, quá trình chuyển đổi mới có thể được gọi.

Cây truy vấn được tạo bởi quy trình chuyển đổi là cấu trúc tương tự như cây kèo bóng đá pháp thô ở hầu hết các nơi, nhưng Nó có nhiều khác biệt về chi tiết. Ví dụ: Afunccall15793_15933funcexprhoặcAggrefnút tùy thuộc vào việc Tên được tham chiếu hóa ra là một hàm thông thường hoặc Hàm tổng hợp. Ngoài ra, thông tin về dữ liệu thực tế Các loại cột và kết quả biểu thức được thêm vào truy vấn cây.