Hệ quản trị cơ sở dữ liệu PostgreSQL có nhiều loại chỉ mục - index
khác nhau, cũng như các cách sử dụng chỉ mục khác nhau. Qua bài viết này, tôi muốn đưa ra một góc nhìn tổng quan về các loại chỉ mục hiện tại đang được PostgreSQL hỗ trợ, và giải thích cách sử dụng khác nhau của loại chỉ mục phổ biến nhất - B-Tree
.
Sử dụng chỉ mục là một cách hiệu quả để truy xuất số lượng tương đối nhỏ các bản ghi từ bảng dữ liệu. Nó sẽ chỉ hữu ích khi số lượng các bản ghi được truy vấn ra từ một bảng không quá lớn (ví dụ, truy vấn bản ghi theo điều kiện - mệnh đề WHERE
). Chỉ mục B-Tree
sẽ rất hữu ích khi ta muốn tránh phải sắp xếp lại các bản ghi đã được lựa chọn.
1. Các loại chỉ mục:
Postgres hỗ trợ các loại chỉ mục sau:
B-Tree
: Hầu như, tất cả các cơ sở dữ liệu hiện nay đều hỗ trợ loại chỉ mụcB-Tree
, và trong hệ quản trị cơ sở dữ liệu PostgreSQL thìB-Tree
là chỉ mục mặc định nếu như thực hiện câu lệnh truy vấn tạo chỉ mục mặc địnhCREATE INDEX
. ChữB
trongB-Tree
là viết tắt của từ Balanced - nghĩa là cân bằng, và ý tưởng của thuật toán là số lượng dữ liệu trên cả nhánh của cây dữ liệu sẽ tương đối bằng nhau. Do đó, số lần phải thực hiện tìm bản ghi ở hai bên luôn luôn giống nhau. Các câu truy vấn bằng hay truy vấn phạm vi sẽ rất hiệu quả nếu kết hợp sử dụng cùng với chỉ mụcB-Tree
, chúng hoạt động với tất cả các kiểu dữ liệu và cả giá trịNULL
. Loại chỉ mụcB-Tree
được thiết kế để có thể làm việc tốt với cơ chế cache, thậm chí ngay cả khi chỉ cache một phần của dữ liệu.Hash
: Chỉ mụcHash
chỉ hữu ích khi truy vấn so sánh bằng, nhưng có thể bạn sẽ không bao giờ sử dụng đến loại chỉ mục này vì nó không an toàn, bạn sẽ cần phải tự đánh lại chỉ mục nếu như có lỗi xảy ra nhưng các đối tượng liên quan sẽ không được thông báo về sự thay đổi này, vì vậy ưu điểm của loại chỉ mụcHash
so với loại chỉ mụcB-Tree
là không đáng kể.