MySQL에서 UUID를 숫자로 저장하는 방법
UUID를 숫자로 저장하면 문자열로 저장하는 것보다 성능 이점이 있습니다. MySQL에서 이를 달성하는 방법에 대한 단계별 가이드는 다음과 같습니다.
MySQL에서 BINARY 필드를 생성합니다.
바이너리 UUID의 길이(이 예에서는 16)와 일치하는 길이로 MySQL 테이블에 BINARY 필드를 만듭니다. 이 작업은 다음을 사용하여 수행할 수 있습니다.
CREATE TABLE my_table ( uuid BINARY(16) NOT NULL );
바이너리 UUID 삽입:
UNHEX() 함수를 사용하여 필드에 바이너리 UUID를 삽입합니다.
INSERT INTO my_table (uuid) VALUES (UNHEX('110E8400E29B11D4A716446655440000'));
UUID 검색 및 변환:
데이터베이스에서 UUID를 검색할 때 BINARY 필드를 선택하고 HEX() 함수를 사용하여 하이픈으로 연결된 UUID로 다시 변환:
SELECT HEX(uuid) AS original_uuid FROM my_table;
Ruby 코드 통합:
삽입:
ActiveSupport::Digest::UUID.binary_pack(uuid)를 사용하여 UUID를 이진 문자열로 변환합니다. 그런 다음 필드에 삽입하기 전에 UNHEX() 함수를 사용하여 16진수 문자열로 변환합니다.
검색:
필드에서 바이너리 UUID를 검색하여 문자열로 변환합니다. HEX()를 사용하는 16진수 문자열입니다. 그런 다음 ActiveSupport::Digest::UUID.uuid_unpack()을 사용하여 16진수 UUID를 다시 원래 형식으로 변환할 수 있습니다.
위 내용은 성능 향상을 위해 MySQL에 UUID를 숫자로 저장하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!