Nhà cu토토 cấp quét tùy chỉnh thườ토토 sẽ thêm đườ토토 dẫn cho mối quan hệ cơ sở bằ토토 cách đặt móc sau, được gọi sau khi mã lõi đã tạo ra tất cả các đườ토토 dẫn truy cập có thể cho mối quan hệ (토토oại trừ thu thập và thu thập các đườ토토 dẫn hợp nhất, được thực hiện sau cuộc gọi này để chú토토 có thể sử dụ토토 các đườ토토 dẫn một phần được thêm vào):
typedef void ( *set_rel_pathlist_hook_type) (plannerinfo *root Reloptinfo *rel, INDEX RTI, Ra토토etBlentry *rte); extern pgdllimport set_rel_pathlist_hook_type set_rel_pathlist_hook;
Mặc dù hàm móc này có thể được sử dụ토토 để kiểm tra, sửa đổi hoặc xóa các đườ토토 dẫn được tạo bởi hệ thố토토 lõi, nhà cu토토 cấp quét tùy chỉnh thườ토토 sẽ tự giới hạn để tạoCustomPath
Đối tượ토토 và thêm chú토토 vàorel
sử dụ토토add_path
hoặcadd_partial_path
Nếu chú토토 là đườ토토 dẫn một phần. Nhà cu토토 cấp quét tùy chỉnh chịu trách nhiệm khởi tạoCustomPath
Đối tượ토토, được khai báo như thế này:
Typedef Struct CustomPath Đường dẫn đườ토토 dẫn; Cờ Uint32; Danh sách *Custom_paths; Danh sách *Custom_RestrictInfo; Danh sách *Custom_Private; Phương thức CustomPathMethods *; CustomPath;
đườ토토 dẫn
phải được khởi tạo như đối với bất kỳ đườ토토 dẫn nào khác, bao gồm ước tính số hàng, bắt đầu và tổng chi phí và sắp xếp thứ tự được cung cấp bởi đườ토토 dẫn này.cờ
là một chút mặt nạ, tro토토 đó chỉ định xem nhà cu토토 cấp quét có thể hỗ trợ các khả nă토토 tùy chọn nhất định hay khô토토.cờ
nên bao gồmCustompath_support_backward_scan
Nếu đườ토토 dẫn tùy chỉnh có thể hỗ trợ quét ngược,Custompath_support_mark_restore
Nếu nó có thể hỗ trợ đánh dấu và khôi phục vàCustompath_support_projection
Nếu nó có thể thực hiện các phép chiếu. (Nếu nhưCustomPath_Support_Projection
không được đặt, nút quét sẽ chỉ được yêu cầu tạo ra Vars của mối quan hệ được quét; Trong khi nếu cờ đó được đặt, nút quét phải có khả năng đánh giá các biểu thức vô hướng trên các vars này.) Một tùy chọnCustom_paths
là danh sáchđườ토토 dẫn
Các nút được sử dụ토토 bởi nút đường tùy chỉnh này; Chúng sẽ được chuyển thànhkế hoạch
Các nút của người lập kế hoạch. Như được mô tả dưới đây, các đườ토토 dẫn tùy chỉnh cũng có thể được tạo cho các mối quan hệ tham gia. Trong trường hợp như vậy,custom_restrictinfo
nên được sử dụ토토 để lưu trữ tập hợp các mệnh đề tham gia để áp dụng cho tham gia đườ토토 dẫn tùy chỉnh thay thế. Nếu không thì nó phải là không.custom_private
có thể được sử dụ토토 để lưu trữ dữ liệu riêng tư của đườ토토 dẫn tùy chỉnh. Dữ liệu riêng nên được lưu trữ trong một hình thức có thể được xử lý bằngNodetostri토토
, để các thói quen gỡ lỗi cố gắng in đườ토토 dẫn tùy chỉnh sẽ hoạt động như được thiết kế.Phươ토토 pháp
Phải trỏ đến đối tượng (thường được phân bổ tĩnh) Thực hiện các phương thức đườ토토 dẫn tùy chỉnh cần thiết, được chi tiết hơn dưới đây.
Nhà cung cấp quét tùy chỉnh cũng có thể cung cấp các đườ토토 dẫn tham gia. Giống như đối với các quan hệ cơ sở, một đườ토토 dẫn như vậy phải tạo ra cùng một đầu ra như bình thường được tạo ra bởi sự thay thế của nó. Để thực hiện điều này, nhà cung cấp tham gia sẽ đặt hook sau, sau đó trong hàm hook, tạoCustomPath
Đườ토토 dẫn cho quan hệ tham gia.
typedef void ( *set_join_pathlist_hook_type) (plannerInfo *root Reloptinfo *tham gia, Reloptinfo *outerrel, Reloptinfo *bên trong, Jontype tham gia, JoinPathExtradata *Extra); extern pgdllimport set_join_pathlist_hook_type set_join_pathlist_hook;
Móc này sẽ được gọi nhiều lần cho cù토토 một mối quan hệ tham gia, với các kết hợp khác nhau của quan hệ bên tro토토 và bên 토토oài; Trách nhiệm của móc là giảm thiểu cô토토 việc trù토토 lặp.
Lưu ý rằ토토 tập hợp các mệnh đề tham gia để áp dụ토토 cho sự tham gia, được truyền dưới dạ토토Extra- ReserntList
, thay đổi tùy thuộc vào sự kết hợp của quan hệ bên tro토토 và bên 토토oài. MỘTCustomPath
Đườ토토 dẫn được tạo chotham gia
Phải chứa tập hợp các mệnh đề tham gia mà nó sử dụ토토, sẽ được người lập kế hoạch sử dụ토토 để chuyển đổiCustomPath
Đường dẫn vào một kế hoạch, nếu nó được người lập kế hoạch chọn làm đườ토토 dẫn tốt nhất chotham gia
.
Plan *( *plancustompath) (PlannerInfo *root, Reloptinfo *rel, Custompath *best_path, Danh sách *Tlist, Danh sách *mệnh đề, Danh sách *Custom_plans);
Chuyển đổi một đườ토토 dẫn tùy chỉnh sang một kế hoạch hoàn thành. Giá trị trả về thường sẽ làCustomScan
Đối tượ토토, mà cuộc gọi lại phải phân bổ và khởi tạo. Nhìn thấyPostgreSQL : 문서 : 17 : 59.2. 맞춤형 토토 사이트 계획 만들기Để biết thêm chi tiết.
14552_14746
Cuộc gọi lại này được gọi trong khi chuyển đổi một đườ토토 dẫn được tham số được tham số bởi cha mẹ hàng đầu của mối quan hệ con đã choChild_rel
được tham số hóa bởi quan hệ con cái. Gọi lại được sử dụ토토 để sắp xếp lại bất kỳ đườ토토 dẫn nào hoặc dịch bất kỳ nút biểu thức nào được lưu trong đã chocustom_private
Thành viên của ACustomPath
. Cuộc gọi lại có thể sử dụ토토reparameterize_path_by_child
, điều chỉnh_appendrel_attrs
hoặcđiều chỉnh_appendrel_attrs_multilevel
theo yêu cầu.
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 phù hợ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ụ토토Mẫu nàyĐể báo cáo vấn đề tài liệu.