SQL에서 SHA256 해시에 대한 해밍 거리를 효율적으로 계산하려면 어떻게 해야 합니까?
Oct 25, 2024 am 08:53 AM이진 문자열에 대한 SQL의 해밍 거리 계산
에 저장된 SHA256 해시 간의 해밍 거리를 계산하는 효율적인 방법을 찾는 데 문제가 발생합니다. BINARY(32) 열. 이진 문자열을 하위 문자열로 분해하여 정수로 변환하고 하위 문자열별 해밍 거리 계산을 수행하는 간단한 접근 방식은 번거롭고 비효율적으로 보입니다.
그러나 성능을 크게 향상시키는 대체 솔루션이 있습니다. 각각 원본 데이터의 8바이트 하위 문자열을 포함하는 4개의 BIGINT 열에 해시를 저장하면 다음 함수를 활용할 수 있습니다.
<code class="sql">CREATE FUNCTION HAMMINGDISTANCE( A0 BIGINT, A1 BIGINT, A2 BIGINT, A3 BIGINT, B0 BIGINT, B1 BIGINT, B2 BIGINT, B3 BIGINT ) RETURNS INT DETERMINISTIC RETURN BIT_COUNT(A0 ^ B0) + BIT_COUNT(A1 ^ B1) + BIT_COUNT(A2 ^ B2) + BIT_COUNT(A3 ^ B3);</code>
이 함수는 비트별 XOR 연산을 수행하여 해밍 거리를 계산합니다. 그리고 결과에서 1의 개수를 세어보세요. 이 접근 방식은 이진 문자열 분해 방법보다 상당히 빠릅니다.
또한 효율성 향상을 위해 BINARY 열 대신 BIGINT 열을 사용하여 해시를 저장하는 것이 좋습니다. BIGINT를 사용하는 이 대체 방법은 실행 속도를 100배 이상 향상시킬 수 있습니다.
위 내용은 SQL에서 SHA256 해시에 대한 해밍 거리를 효율적으로 계산하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

인기 기사

인기 기사

뜨거운 기사 태그

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까?

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다.

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음)

일반적인 취약점 (SQL 주입, 무차별 적 공격)에 대해 MySQL을 어떻게 보호합니까?
