Postgresql 8.3.23 Tài liệu | ||||
---|---|---|---|---|
Prev | Backward nhanh | Chương 43. Tổng quan về PostgreSQL Internals | Chuyển tiếp nhanh | Tiếp theo |
Nhiệm vụ củaNgười lập cách đọc kèo bóng đáIS Để tạo ra một cách đọc kèo bóng đá thực hiện tối ưu. Một truy vấn SQL nhất định (và Do đó, một cây truy vấn) thực sự có thể được thực hiện trong nhiều loại theo các cách khác nhau, mỗi cách sẽ tạo ra cùng một bộ kết quả. Nếu nó khả thi về mặt tính toán, trình tối ưu hóa truy vấn sẽ kiểm tra từng cách đọc kèo bóng đá thực thi có thể, cuối cùng chọn cách đọc kèo bóng đá thực thi dự kiến sẽ chạy nhanh nhất.
Lưu ý:Trong một số tình huống, kiểm tra từng tình huống có thể cách thực thi truy vấn có thể được thực thi sẽ mất quá nhiều Lượng thời gian và không gian bộ nhớ. Đặc biệt, điều này xảy ra Khi thực hiện các truy vấn liên quan đến số lượng lớn tham gia hoạt động. Để xác định hợp lý (không nhất thiết phải tối ưu) cách đọc kèo bóng đá truy vấn với số lượng hợp lý của thời gian,PostgreSQLSử dụng Atỷ lệ kèo bóng đá tối nay: Tài liệu: 8Khi số lượng tham gia vượt quá ngưỡng (xemgeqo_threshold).
Quy trình tìm kiếm của người lập cách đọc kèo bóng đá thực sự hoạt động với dữ liệu Cấu trúc được gọi làđường dẫn, đó là Đơn giản chỉ cần cắt giảm các đại diện của các cách đọc kèo bóng đá chỉ chứa nhiều Thông tin như người lập cách đọc kèo bóng đá cần đưa ra quyết định của mình. Sau Đường dẫn rẻ nhất được xác định, một bản thông tin đầy đủCây cách đọc kèo bóng đáđược xây dựng để chuyển cho người thực thi. Cái này đại diện cho cách đọc kèo bóng đá thực thi mong muốn một cách chi tiết đủ cho Người thực thi để chạy nó. Trong phần còn lại của phần này, chúng tôi sẽ bỏ qua sự khác biệt giữa các đường dẫn và cách đọc kèo bóng đá.
12765_13217Mối quan hệ.. Nếu nhưMối quan hệ.Attributionxảy ra để phù hợp Khóa của chỉ mục B-Tree vàOPRIS một trong các toán tử được liệt kê trong chỉ mụcLớp toán tử, một cách đọc kèo bóng đá khác được tạo bằng cách sử dụng Chỉ số B-Tree để quét mối quan hệ. Nếu có thêm chỉ mục hiện tại và các hạn chế trong truy vấn xảy ra Kết hợp một khóa của một chỉ mục, các cách đọc kèo bóng đá tiếp theo sẽ được xem xét. Các cách đọc kèo bóng đá quét chỉ mục cũng được tạo cho các chỉ mục có Sắp xếp thứ tự có thể khớp với truy vấnĐặt hàng bởimệnh đề (nếu có) hoặc một thứ tự sắp xếp Điều đó có thể hữu ích cho việc hợp nhất tham gia (xem bên dưới).
Nếu truy vấn yêu cầu tham gia hai hoặc nhiều quan hệ, cách đọc kèo bóng đá Để tham gia quan hệ được xem xét sau tất cả các cách đọc kèo bóng đá khả thi đã được tìm thấy để quét các mối quan hệ đơn lẻ. Ba Các chiến lược tham gia có sẵn là:
Tham gia vòng lồng nhau: Quyền quan hệ được quét một lần cho mỗi hàng được tìm thấy ở bên trái mối quan hệ. Chiến lược này dễ thực hiện nhưng có thể rất tốn thời gian. (Tuy nhiên, nếu mối quan hệ đúng có thể Được quét bằng quét chỉ mục, đây có thể là một chiến lược tốt. Nó có thể sử dụng các giá trị từ hàng hiện tại của bên trái quan hệ như các phím cho việc quét chỉ mục của bên phải.)
Hợp nhất tham gia: Mỗi quan hệ là Sắp xếp trên các thuộc tính tham gia trước khi tham gia bắt đầu. Sau đó Hai mối quan hệ được quét song song và phù hợp Hàng được cách đọc kèo bóng đát hợp để tạo thành các hàng tham gia. Loại tham gia này là hấp dẫn hơn vì mỗi quan hệ phải được quét Chỉ một lần. Phân loại cần thiết có thể đạt được bằng cách một bước sắp xếp rõ ràng hoặc bằng cách quét mối quan hệ trong Thứ tự thích hợp bằng cách sử dụng một chỉ mục trên khóa nối.
băm tham gia: Mối quan hệ đúng đắn đầu tiên được quét và tải vào bảng băm, sử dụng Tham gia các thuộc tính dưới dạng khóa băm. Tiếp theo mối quan hệ bên trái là được quét và các giá trị thích hợp của mỗi hàng được tìm thấy được sử dụng như các phím băm để xác định vị trí các hàng phù hợp trong bàn.
15616_15840
Nếu truy vấn sử dụng ít hơngeqo_thresholdquan hệ, tìm kiếm gần như đã được thực hiện để tìm Trình tự tham gia tốt nhất. Người lập cách đọc kèo bóng đá ưu tiên xem xét tham gia giữa hai mối quan hệ mà tồn tại một Tham gia mệnh đề trongWHERETrình độ chuyên môn (tức là một hạn chế nhưỞ đâu rel1.attr1 = rel2.ATTR2tồn tại). Tham gia các cặp không có tham gia mệnh đề chỉ được coi là khi không có lựa chọn nào khác, rằng là, một mối quan hệ cụ thể không có sẵn các điều khoản tham gia quan hệ khác. Tất cả các cách đọc kèo bóng đá có thể được tạo cho mỗi lần tham gia cặp được xem xét bởi người lập cách đọc kèo bóng đá, và một trong số (ước tính trở thành) giá rẻ nhất được chọn.
Khigeqo_thresholdbị vượt quá, Các chuỗi tham gia được xem xét được xác định bởi heuristic, vì được mô tả trongChương 49. Nếu không thì quá trình là như nhau.
16901_17215Lựa chọn(loại bỏ các hàng không đáp ứng điều kiện boolean được chỉ định) vàDự đoán(tính toán của một cột dẫn xuất Dựa trên các giá trị cột đã cho, nghĩa là đánh giá vô hướng biểu thức khi cần thiết). Một trong những trách nhiệm của Người lập cách đọc kèo bóng đá phải đính kèm các điều kiện lựa chọn từWHERE17624_17732