- vừa được xem lúc

Hãy cân nhắc nếu bạn có ý định sử dụng UUID làm Khóa chính trong DB.

0 0 10

Người đăng: BKSCloud Team

Theo Viblo Asia

Keep It Simple, Stupid (KISS)

Đây là một trong những nguyên tắc lập trình quan trọng nhất đối với các lập trình viên. Vậy KISS nghĩa là gì? KISS, viết tắt của Keep It Simple, Stupid, có nghĩa là bạn nên viết code càng đơn giản càng tốt. Một trong những quy tắc của lập trình cơ bản là không bao giờ bị cuốn vào việc cố gắng trở nên thông minh quá mức hoặc phô trương với một khối dày đặc code phức tạp. Nếu bạn có thể viết đoạn code trong một dòng, hãy viết nó trong một dòng.

Sử dụng UUID (Universally Unique Identifier) làm khóa chính trong cơ sở dữ liệu SQL có cả lợi và hại. Mặc dù UUID mang lại lợi ích trong một số tình huống, nhưng có những lý do tại sao chúng có thể không phải là lựa chọn tốt nhất cho khóa chính:

Indexing và Hiệu suất:

UUID có độ dài 128 bit, so với 32 bit cho một số nguyên thông thường. Kích thước lớn hơn này có thể dẫn đến yêu cầu lưu trữ tăng và hiệu suất giảm, đặc biệt khi làm việc với dữ liệu lớn.

Các chỉ mục xây dựng trên cột UUID có thể không hoạt động hiệu quả như các chỉ mục trên các loại dữ liệu nhỏ hơn. Điều này là do khóa lớn hơn có thể dẫn đến việc đọc trang nhiều hơn, ảnh hưởng đến hiệu suất truy vấn.

Khả năng đọc và Gỡ lỗi:

UUID không thể đọc được bởi con người, điều này có thể làm cho việc gỡ lỗi và kiểm tra thủ công cơ sở dữ liệu khó khăn hơn. Số nguyên hoặc các loại dữ liệu nhỏ hơn có thể thuận tiện hơn cho nhà phát triển và quản trị cơ sở dữ liệu.

Phân cụm:

UUID được thiết kế để duy nhất toàn cầu, nhưng không đảm bảo tuần tự. Sự thiếu tuần tự này có thể dẫn đến mẫu I/O đĩa không tối ưu, ảnh hưởng đến hiệu suất của một số loại truy vấn, đặc biệt là các truy vấn liên quan đến tìm kiếm dựa trên khoảng giá trị.

Phân mảnh

UUID thường được tạo ra bằng cách kết hợp giá trị thời gian và ngẫu nhiên. Sự ngẫu nhiên này có thể dẫn đến mức độ phân mảnh chỉ mục cao hơn, ảnh hưởng đến hiệu suất cơ sở dữ liệu theo thời gian.

Tốn Dung lượng Lưu trữ:

Lưu trữ UUID có thể dẫn đến yêu cầu lưu trữ tăng, cả về không gian đĩa và bộ nhớ. Điều này có thể là một vấn đề trong môi trường nơi chi phí lưu trữ là quan trọng.

Phức tạp Ứng dụng:

Quản lý UUID, đặc biệt là việc tạo ra chúng và đảm bảo tính duy nhất trên các hệ thống phân tán, có thể làm tăng độ phức tạp của logic ứng dụng. Độ phức tạp này có thể không cần thiết nếu các loại khóa chính đơn giản hơn đủ cho yêu cầu của ứng dụng.

Bình luận

Bài viết tương tự

- vừa được xem lúc

Hướng dẫn cấu hình Database Replication

Đặt vấn đề. Slow Query hoặc timeout là một vấn đề thường gặp khi làm việc với database, vấn đề này ảnh hưởng rất lớn đến performance và trải nghiệm người dùng, thậm chí còn dẫn tới downtime toàn bộ hệ

0 0 29

- vừa được xem lúc

Những sai lầm khi làm việc với CSDL - P1

Từ cậu sinh viên mới tốt nghiệp ĐHBK-HN hệ Việt Nhật được vài tháng, mình nhận lời chuyển sang nhận nhiệm vụ chịu trách nhiệm phát triển sản phẩm cho một startup ~ (lead team khoảng 7-10 người). Sau h

0 0 28

- vừa được xem lúc

Scale Database với kiến trúc Master Slave

Sau bài viết đầu tiên về đầu tiên những sai lầm khi làm việc với CSDL mình đã nhận được rất nhiều chia sẻ tích cực từ. Các anh chị bạn bè cũng đã có những góp ý về cách viết, nội dung, cách sắp xếp cá

0 0 21

- vừa được xem lúc

Giới thiệu về NocoDB

Lời mở đầu. Đối với dân lập trình viên thì cơ sở dữ liệu là một phần quan trọng trong công việc.

0 0 8

- vừa được xem lúc

[MongoDB - phần 3] Nguyên lý triển khai và cấu hình Sharding MongoDB

I. LỜI NÓI ĐẦU.

0 0 1