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

61.3. Thực hiện kèo bóng đá pháp

Khi ACustomScanđược kèo bóng đá pháp thi, trạng thái kèo bóng đá pháp 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;

SSđược khởi tạo như đối với bất kỳ trạng thái kèo bóng đá pháp nào khác, ngoại trừ nếu kèo bóng đá pháp là tham gia chứ không phải là mối quan hệ cơ sở,là NULL.cờ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 kèo bóng đá pháp 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, kèo bóng đá pháp 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ó.

61.3.1. Các cuộc gọi lại thực thi kèo bóng đá pháp

void ( *BeginCustomScan) (nút 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ộ kèo bóng đá pháp tiếp theo. Nếu có bất kỳ bộ dữ liệu nào vẫn còn, nó sẽ lấp đầyps_resulttuplotlotVới bộ xử lý tiếp theo theo hướng kèo bóng đá pháp hiện tại, sau đó trả về khe 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 lần kèo bóng đá pháp 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í kèo bóng đá pháp 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à kèo bóng đá pháp chọn và chỉ cần được cung cấp nếuCustompath_support_mark_restorecờ được đặt.

11599_11654

Khôi phục vị trí kèo bóng đá pháp trước đó được lưu bởiMarkposcustomScangọi lại. Cuộc gọi lại này là kèo bóng đá pháp 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 kèo bóng đá pháp này hỗ trợ thực thi song song.

void ( *khởi tạoSmcustomScan) (CustomScanstate *Node,
                                 Song song
                                 void *tọa độ);

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 kèo bóng đá pháp này hỗ trợ thực thi song song.

void ( *ReinitializedSmcustomScan) (CustomScanstate *Node,
                                   Song song
                                   void *tọa độ);

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 kèo bóng đá pháp 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 kèo bóng đá pháp 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 khiRescancustomScanChua lại chỉ đặt lại trạng thái cục bộ. kèo bóng đá pháp 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 cục bộ 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 kèo bóng đá pháp 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 kèo bóng đá pháp để 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 kèo bóng đá pháp 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) (nút 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 kèo bóng đá pháp. 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ệ kèo bóng đá pháp, 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 kèo bóng đá pháp

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.