MySQL이 고유 필드의 후행 공백을 무시하는 이유는 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-10-31 21:12:29
원래의
311명이 탐색했습니다.

Why Is MySQL Ignoring Trailing Spaces in Unique Fields?

고유 필드의 후행 공백을 무시하는 MySQL 데이터베이스

MySQL에서 고유 필드가 있는 데이터베이스를 생성할 때 값에 선행 또는 후행이 포함되어야 합니다. 공백은 별개로 취급되어야 합니다. 그러나 삽입 중에 후행 공백이 잘려져 다양한 후행 공백이 있는 단어를 삽입하려고 하면 중복 값 오류가 발생하는 것으로 관찰되었습니다.

근본적인 문제는 후행 공백을 무시하는 MySQL의 기본 문자열 비교 동작에 있습니다. 결과적으로 UNIQUE 인덱스는 표준 문자열 비교를 사용하여 후행 공백을 무시하고 문자 동일성에 따라 삽입을 거부합니다.

이 문제를 해결하기 위한 한 가지 접근 방식은 값을 VARBINARY로 저장하는 것입니다. 후행 공백을 존중하는 고유 인덱스 생성. 다양한 공백으로 값을 저장할 수 있지만 이러한 값을 기준으로 정렬하면 예상한 결과가 나오지 않을 수 있다는 점에 유의하는 것이 중요합니다.

대체 솔루션은 MySQL 8.0에 도입된 MySQL의 NO PAD 데이터 정렬을 활용하는 것입니다. . utf8mb4_0900_ai_ci와 같은 이러한 데이터 정렬은 후행 공백을 무시하지 않고 문자열 비교를 처리합니다. NO PAD 데이터 정렬을 사용하여 고유한 필드를 생성하면 후행 공백이 다양한 값이 고유한 값으로 처리되도록 할 수 있습니다.

위 내용은 MySQL이 고유 필드의 후행 공백을 무시하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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