성능 향상을 위해 MySQL에 UUID를 숫자로 저장하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-11-17 03:26:03
원래의
881명이 탐색했습니다.

How to Store UUIDs as Numbers in MySQL for Performance Gains?

MySQL에서 UUID를 숫자로 저장하는 방법

UUID를 숫자로 저장하면 문자열로 저장하는 것보다 성능 이점이 있습니다. MySQL에서 이를 달성하는 방법에 대한 단계별 가이드는 다음과 같습니다.

  1. UUID를 이진 문자열로 변환:
    UUID에서 대시를 제거하고 변환합니다. 단일 이진 문자열로. 예를 들어 원래 UUID가 "110E8400-E29B-11D4-A716-446655440000"인 경우 "110E8400E29B11D4A716446655440000"이 됩니다.
  2. MySQL에서 BINARY 필드를 생성합니다.
    바이너리 UUID의 길이(이 예에서는 16)와 일치하는 길이로 MySQL 테이블에 BINARY 필드를 만듭니다. 이 작업은 다음을 사용하여 수행할 수 있습니다.

    CREATE TABLE my_table (
        uuid BINARY(16) NOT NULL
    );
    로그인 후 복사
  3. 바이너리 UUID 삽입:
    UNHEX() 함수를 사용하여 필드에 바이너리 UUID를 삽입합니다.

    INSERT INTO my_table (uuid) VALUES (UNHEX('110E8400E29B11D4A716446655440000'));
    로그인 후 복사
  4. UUID 검색 및 변환:
    데이터베이스에서 UUID를 검색할 때 BINARY 필드를 선택하고 HEX() 함수를 사용하여 하이픈으로 연결된 UUID로 다시 변환:

    SELECT HEX(uuid) AS original_uuid FROM my_table;
    로그인 후 복사
  5. Ruby 코드 통합:

    삽입:
    ActiveSupport::Digest::UUID.binary_pack(uuid)를 사용하여 UUID를 이진 문자열로 변환합니다. 그런 다음 필드에 삽입하기 전에 UNHEX() 함수를 사용하여 16진수 문자열로 변환합니다.

    검색:
    필드에서 바이너리 UUID를 검색하여 문자열로 변환합니다. HEX()를 사용하는 16진수 문자열입니다. 그런 다음 ActiveSupport::Digest::UUID.uuid_unpack()을 사용하여 16진수 UUID를 다시 원래 형식으로 변환할 수 있습니다.

위 내용은 성능 향상을 위해 MySQL에 UUID를 숫자로 저장하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿