MySQL에서 UUID를 숫자로 저장
MySQL에서 UUID를 문자열로 저장하면 특히 인덱싱과 관련된 경우 성능 문제가 발생할 수 있습니다. 전문가가 제안한 또 다른 접근 방식은 성능 향상을 위해 UUID를 숫자로 저장하는 것입니다. Ruby에서 이 작업을 수행하는 방법을 살펴보겠습니다.
대시 제거 및 바이너리로 변환
첫 번째 단계는 UUID에서 대시를 제거하는 것입니다. 예를 들어 "110E8400-E29B-11D4-A716-446655440000"과 같은 UUID는 "110E8400E29B11D4A716446655440000"이 됩니다.
UUID는 128비트로 구성되므로 BINARY(16) 데이터 유형으로 저장할 수 있습니다. MySQL에서. MySQL의 BINARY 데이터 유형은 문자열보다 처리에 더 효율적인 이진 표현을 사용합니다.
SQL 쿼리 예
BINARY 필드에 UUID를 삽입하려면 다음을 사용하세요. 다음 쿼리:
INSERT INTO table_name (field_binary) VALUES (UNHEX("110E8400E29B11D4A716446655440000"))
UUID를 검색하려면 다음 쿼리를 사용합니다.
SELECT HEX(field_binary) AS field_binary FROM table_name
Ruby 코드 통합
Ruby에서, UUIDtools gem을 사용하여 UUID를 생성하고 이를 바이너리로 변환할 수 있습니다. gem은 UUID.new 및 UUID.hex_to_bin과 같은 메소드를 제공합니다. 예:
require 'uuidtools' # Generate a UUID as a string uuid = UUID.new # Remove dashes and convert to binary binary_uuid = uuid.to_s.gsub("-", "").hex_to_bin # Store the binary UUID in MySQL # ... # Retrieve the binary UUID from MySQL # ... # Reconstruct the original UUID with dashes new_uuid = binary_uuid.bin_to_hex.gsub(/(.{8})(.{4})(.{4})(.{4})(.{12})/, '----')
이러한 단계를 수행하면 MySQL에서 UUID를 이진수로 효율적으로 저장하고 검색할 수 있어 인덱스된 UUID를 사용할 때 성능이 향상됩니다.
위 내용은 성능 향상을 위해 MySQL에 UUID를 숫자로 저장하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!