Giá trị hex của bạn có phải là GUID không? Mặc dù tôi đã từng lo lắng về hiệu suất của các mục dài như chỉ mục, tôi nhận thấy rằng trên cơ sở dữ liệu hiện đại, sự khác biệt về hiệu suất trên thậm chí hàng triệu bản ghi là khá không đáng kể.
Một vấn đề tiềm ẩn lớn hơn là bộ nhớ mà chỉ mục sử dụng (ví dụ:16 byte so với 4 byte int), nhưng trên các máy chủ mà tôi kiểm soát, tôi có thể cấp phát cho điều đó. Miễn là chỉ mục có thể nằm trong bộ nhớ, tôi thấy rằng có nhiều chi phí từ các hoạt động khác mà kích thước của phần tử chỉ mục không tạo ra sự khác biệt đáng chú ý.
Mặt khác, nếu bạn sử dụng GUID, bạn có được sự độc lập của máy chủ đối với các bản ghi được tạo và linh hoạt hơn trong việc hợp nhất dữ liệu trên nhiều máy chủ (đó là điều tôi quan tâm, vì hệ thống của chúng tôi tổng hợp dữ liệu từ các hệ thống con).
Có một biểu đồ trên bài viết này dường như chứng minh cho nghi ngờ của tôi: Thần thoại, GUID so với Tự động gia tăng