Phiên bản được hỗ trợ:Postgresql: Tài liệu: 17:(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

59.3. Thực hiện soi kèo bóng đá truoctran

Khi ACustomScanđược soi kèo bóng đá truoctran thi, trạng thái soi kèo bóng đá truoctran thi của nó được biểu thị bằng mộtCustomScanstate, được khai báo như sau:

Typedef Struct CustomScanState

    Scanstate SS;
    Cờ Uint32;
    Phương pháp Const CustomExecMethods *;
 CustomScanState;

SS8981_9095SS.SS_CienRelationcờlà một chút mặt nạ có cùng ý nghĩa như trongCustomPathCustomScan. Phương phápphải trỏ đến một đối tượng (thường được phân bổ tĩnh) thực hiện các phương thức trạng thái soi kèo bóng đá truoctran cần thiết, được chi tiết hơn dưới đây. Thông thường, ACustomScanstate, không cần hỗ trợCopyObject, soi kèo bóng đá truoctran sự sẽ là một cấu trúc lớn hơn nhúng ở trên là thành viên đầu tiên của nó.

59.3.1. Các cuộc gọi lại thực thi soi kèo bóng đá truoctran

void ( *BeginCustomScan) (CustomScanState *Node,
                         Bất động sản *Bất động sản,
                         int eflags);

Khởi tạo hoàn toàn được cung cấpCustomScanState. Các trường tiêu chuẩn đã được khởi tạo bởiExecItCustomScan, nhưng bất kỳ trường riêng nào cũng nên được khởi tạo ở đây.

TupleTablesLot *( *ExecCustomScan) (CustomScanState *Node);

Lấy bộ soi kèo bóng đá truoctran tiếp theo. Nếu có bất kỳ bộ dữ liệu nào vẫn còn, nó sẽ lấp đầyps_resulttuplotVới bộ tiếp theo theo hướng soi kèo bóng đá truoctran hiện tại, sau đó trả về khe cắm Tuple. Nếu không,nullhoặc một khe trống phải được trả về.

void ( *EndCustomScan) (CustomScanState *Node);

Làm sạch bất kỳ dữ liệu riêng tư nào được liên kết vớiCustomScanstate. Phương pháp này là bắt buộc, nhưng nó không cần phải làm bất cứ điều gì nếu không có dữ liệu liên quan hoặc nó sẽ được làm sạch tự động.

void ( *RescancustomScan) (CustomScanState *Node);

Tua lại quá trình soi kèo bóng đá truoctran hiện tại đến đầu và chuẩn bị cứu lại mối quan hệ.

void ( *markposcustomscan) (CustomScanState *Node);

Lưu vị trí soi kèo bóng đá truoctran hiện tại để sau đó có thể được khôi phục bởireprposcustomscangọi lại. Cuộc gọi lại này là soi kèo bóng đá truoctran chọn và chỉ cần được cung cấp nếuCustompath_support_mark_restorecờ được đặt.

11648_11703

11715_11768MarkposcustomScangọi lại. Cuộc gọi lại này là soi kèo bóng đá truoctran chọn và chỉ cần được cung cấp nếuCustompath_support_mark_restorecờ được đặt.

kích thước ( *ước tínhSmcustomScan) (CustomScanstate *Node,
                               Song song với các

Ước tính lượng bộ nhớ chia sẻ động sẽ được yêu cầu cho hoạt động song song. Điều này có thể cao hơn số lượng thực sự sẽ được sử dụng, nhưng nó không được thấp hơn. Giá trị trả về là trong byte. Cuộc gọi lại này là tùy chọn và chỉ cần được cung cấp nếu nhà cung cấp soi kèo bóng đá truoctran này hỗ trợ thực thi song song.

12475_12642

Khởi tạo bộ nhớ chia sẻ động sẽ được yêu cầu cho hoạt động song song.tọa độĐiểm vào vùng bộ nhớ được chia sẻ có kích thước bằng với giá trị trả về củaƯớc tínhSmcustomScan. Cuộc gọi lại này là tùy chọn và chỉ cần được cung cấp nếu nhà cung cấp soi kèo bóng đá truoctran này hỗ trợ thực thi song song.

13045_13218

Tái tạo bộ nhớ chia sẻ động cần thiết cho hoạt động song song khi nút Kế hoạch soi kèo bóng đá truoctran sắp được quét lại. Cuộc gọi lại này là tùy chọn và chỉ cần được cung cấp nếu nhà cung cấp soi kèo bóng đá truoctran này hỗ trợ thực thi song song. Thực hành được đề xuất là đặt lại lại trạng thái được chia sẻ, trong khiRescancustomScanCallback đặt lại trạng thái cục bộ. soi kèo bóng đá truoctran tại, cuộc gọi lại này sẽ được gọi trướcRescancustomScan, nhưng tốt nhất là không dựa vào thứ tự đó.

VOID ( *Khởi tạo công tác dụng cụ
                                    shm_toc *toc,
                                    void *tọa độ);

Khởi tạo trạng thái địa phương của công nhân song song dựa trên trạng thái chia sẻ do người lãnh đạo thiết lập trongkhởi tạoSmcustomScan. Cuộc gọi lại này là tùy chọn và chỉ cần được cung cấp nếu nhà cung cấp soi kèo bóng đá truoctran này hỗ trợ thực thi song song.

void ( *ShutdownCustomScan) (CustomScanState *Node);

Phát hành tài nguyên khi dự đoán, nút sẽ không được thực soi kèo bóng đá truoctran để hoàn thành. Điều này không được gọi trong tất cả các trường hợp; Thỉnh thoảng,EndCustomScanCó thể được gọi mà không có chức năng này được gọi là đầu tiên. Vì phân đoạn DSM được sử dụng bởi truy vấn song song bị phá hủy ngay sau khi cuộc gọi lại này được gọi, các nhà cung cấp soi kèo bóng đá truoctran muốn thực hiện một số hành động trước khi phân đoạn DSM biến mất nên thực hiện phương thức này.

void ( *Giải thíchCustomScan) (CustomScanstate *Node,
                           Danh sách *Tổ tiên,
                           Giải thích *es);

xuất thông tin bổ sung choGiải thíchcủa nút kế hoạch soi kèo bóng đá truoctran. Cuộc gọi lại này là tùy chọn. Dữ liệu phổ biến được lưu trữ trongScanState, chẳng hạn như danh sách đích và quan hệ soi kèo bóng đá truoctran, sẽ được hiển thị ngay cả khi không có cuộc gọi lại này, nhưng cuộc gọi lại cho phép hiển thị trạng thái riêng, riêng tư.

Gửi hiệu soi kèo bóng đá truoctran

Nếu bạn thấy bất cứ điều gì trong tài liệu không chính xác, không khớp Kinh nghiệm của bạn với tính năng cụ thể hoặc yêu cầu làm rõ thêm, Vui lòng sử dụngMẫu nàyĐể báo cáo vấn đề tài liệu.