Các ví dụ trong phần trước được minh họa toàn bộ văn bản khớp bằng cách sử dụng các chuỗi hằng số đơn giản. Phần này cho thấy cách tìm kiếm dữ liệu bảng, tùy chọn sử dụng các chỉ kèo bóng đá c1.
Có thể thực hiện tìm kiếm văn bản đầy đủ mà không cần chỉ kèo bóng đá c1. Một truy vấn đơn giản để inTiêu đề
của mỗi hàng có chứa từbạn
Trong nóBody
Trường là:
Chọn tiêu đề
Điều này cũng sẽ tìm thấy các từ liên quan nhưbạn bè
vàthân thiện
, vì tất cả những thứ này được giảm xuống cùng một từ vựng được chuẩn hóa.
Truy vấn ở trên chỉ định rằngtiếng Anh
Cấu hình sẽ được sử dụng để phân tích và bình thường hóa các chuỗi. Ngoài ra, chúng tôi có thể bỏ qua các tham số cấu hình:
Chọn tiêu đề
Truy vấn này sẽ sử dụng cấu hình được đặt bởidefault_text_search_config.
Một ví dụ phức tạp hơn là chọn mười tài liệu gần đây nhất có chứaTạo
vàkèo bóng đá c1
trongTiêu đề
hoặcBody
:
Chọn tiêu đề
Để rõ ràng, chúng tôi đã bỏ quaHOUNESCE
Các cuộc gọi chức năng cần thiết để tìm các hàng có chứanull
Trong một trong hai trường.
Mặc dù các truy vấn này sẽ hoạt động mà không có chỉ kèo bóng đá c1, hầu hết các ứng dụng sẽ thấy phương pháp này quá chậm, ngoại trừ có lẽ đối với các tìm kiếm ad-hoc thường xuyên. Sử dụng thực tế tìm kiếm văn bản thường yêu cầu tạo một chỉ kèo bóng đá c1.
Chúng ta có thể tạo AGinindex (Phần 12.9) Để tăng tốc các tìm kiếm văn kèo bóng đá c1:
12772_12849
Lưu ý rằng phiên kèo bóng đá c1 2 đối số củato_tsVector
được sử dụng. Chỉ có thể sử dụng các chức năng tìm kiếm văn bản chỉ định tên cấu hình có thể được sử dụng trong các chỉ kèo bóng đá c1 biểu thức (Phần 11.7). Điều này là do nội dung chỉ kèo bóng đá c1 phải không bị ảnh hưởng bởidefault_text_search_config. Nếu chúng bị ảnh hưởng, nội dung chỉ kèo bóng đá c1 có thể không nhất quán vì các kèo bóng đá c1 khác nhau có thể chứatsVector
s được tạo với các cấu hình tìm kiếm văn bản khác nhau và sẽ không có cách nào để đoán đó là cái nào. Không thể bỏ và khôi phục một chỉ kèo bóng đá c1 như vậy một cách chính xác.
Bởi vì phiên kèo bóng đá c1 hai đối số củato_tsVector
Đã được sử dụng trong chỉ kèo bóng đá c1 ở trên, chỉ có một tham chiếu truy vấn sử dụng phiên bản 2-parument củaTO_TSVECTOR
Với cùng tên cấu hình sẽ sử dụng chỉ kèo bóng đá c1 đó. Đó là,WHERE TO_TSVECTOR ('English', body) @@ 'A & B'
có thể sử dụng chỉ kèo bóng đá c1, nhưngWHERE TO_TSVECTOR (BODY) @@ 'A & B'
Không thể. Điều này đảm bảo rằng một chỉ kèo bóng đá c1 sẽ chỉ được sử dụng với cùng một cấu hình được sử dụng để tạo các kèo bóng đá c1 nhập chỉ kèo bóng đá c1.
Có thể thiết lập các chỉ kèo bóng đá c1 biểu thức phức tạp hơn trong đó tên cấu hình được chỉ định bởi một cột khác, ví dụ:
14392_14471
WHEREconfig_name
là một cột trongPGWEB
Bảng. Điều này cho phép các cấu hình hỗn hợp trong cùng một chỉ kèo bóng đá c1 trong khi ghi cấu hình nào được sử dụng cho mỗi kèo bóng đá c1 nhập chỉ kèo bóng đá c1.WHERE TO_TSVECTOR (config_name, body) @@ 'A & B'
.
Chỉ kèo bóng đá c1 thậm chí có thể kết nối các cột:
15061_15154
Một cách tiếp cận khác là tạo riêng biệttsVector
Cột để giữ đầu ra củaTO_TSVECTOR
. Để giữ cho cột này tự động cập nhật với dữ liệu nguồn của nó, hãy sử dụng cột được tạo được lưu trữ.Tiêu đề
vàBody
, sử dụngHOUNESCE
Để đảm bảo rằng một trường vẫn sẽ được lập chỉ kèo bóng đá c1 khi phần kia lànull
:
thay đổi kèo bóng đá c1 pgweb
sau đó chúng ta tạo mộtGinChỉ kèo bóng đá c1 để tăng tốc tìm kiếm:
16024_16102
Bây giờ chúng tôi đã sẵn sàng để thực hiện tìm kiếm văn kèo bóng đá c1 đầy đủ nhanh:
Chọn tiêu đề
Một lợi thế của cách tiếp cận cột riêng biệt so với chỉ kèo bóng đá c1 biểu thức là không cần thiết phải chỉ định rõ ràng cấu hình tìm kiếm văn bản trong các truy vấn để sử dụng chỉ kèo bóng đá c1. Như được hiển thị trong ví dụ trên, truy vấn có thể phụ thuộc vàodefault_text_search_config
. Một lợi thế khác là các tìm kiếm sẽ nhanh hơn, vì sẽ không cần thiết để làm lạiTO_TSVECTOR
Các cuộc gọi để xác minh các kết quả khớp. (Điều này quan trọng hơn khi sử dụng chỉ kèo bóng đá c1 GIST hơn chỉ kèo bóng đá c1 gin; xemPhần 12.9.) Tuy nhiêntsVector
Đại diện không được lưu trữ rõ ràng.
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ợpMẫu nàyĐể báo cáo vấn đề tài liệu.