Có, có các ràng buộc khóa ngoại tại chỗ có thể cải thiện hiệu suất truy vấn. Có nhiều biến đổi khác nhau được mở cho trình tối ưu hóa khi tồn tại các ràng buộc khóa ngoại thích hợp mà thường không có sẵn. Ví dụ:nếu bạn tham gia A
và B
nhưng chỉ chọn dữ liệu từ B
, trình tối ưu hóa có thể loại bỏ A
hoàn toàn từ kế hoạch truy vấn nếu có một ràng buộc khóa ngoại tại chỗ (loại điều này rất hữu ích khi bạn có các dạng xem hữu ích tham gia vào nhiều bảng hơn truy vấn hiện tại của bạn một cách nghiêm ngặt vì bạn không phải đánh đổi chi phí hiệu suất của các phép nối bổ sung so với việc sử dụng lại mã từ chế độ xem hiện có). Chúng cũng rất hữu ích khi bạn đang làm những việc như sử dụng những thứ như ghi lại truy vấn để viết lại truy vấn nhằm sử dụng chế độ xem cụ thể hóa trong kho dữ liệu / hệ thống loại DSS.
Tom Kyte có bản trình bày Các vấn đề siêu dữ liệu nói về cách các loại ràng buộc khác nhau, cùng với các phần siêu dữ liệu khác, có thể ảnh hưởng đến trình tối ưu hóa.