> 데이터 베이스 > MySQL 튜토리얼 > SQL Server의 `WHERE` 절은 문자열 비교에서 후행 공백을 무시합니까?

SQL Server의 `WHERE` 절은 문자열 비교에서 후행 공백을 무시합니까?

Linda Hamilton
풀어 주다: 2025-01-05 01:48:38
원래의
1032명이 탐색했습니다.

Does SQL Server's `WHERE` Clause Ignore Trailing Spaces in String Comparisons?

SQL WHERE 절: 값 일치의 후행 공백

SQL Server에서 WHERE 절을 사용한 문자열 비교는 다음과 같은 특이한 동작을 나타냅니다. 예상치 못한 결과에. 특히 항등 연산자(=)는 비교를 수행할 때 후행 공백을 무시합니다.

다음 시나리오를 고려하십시오.

  • Zone이라는 테이블에는 varchar 유형의 ZoneReference라는 기본 키 열이 있습니다. (50) NOT NULL 제약 조건을 사용합니다.
  • ZoneReference 값에 대해 QuotedZoneReference 값을 선택하기 위해 쿼리가 실행됩니다. of 'WF11XU':
select '"' + ZoneReference + '"' as QuotedZoneReference
from Zone
where ZoneReference = 'WF11XU'
로그인 후 복사

놀랍게도 쿼리는 다음 결과를 반환합니다.

"WF11XU "
로그인 후 복사

설명:

이것은 동작은 비교 작업의 문자열을 다음으로 채워야 함을 지시하는 SQL-92 사양에서 비롯됩니다. 비교하기 전에 길이가 같은지 확인하십시오. 이 경우 WHERE 절의 ZoneReference 값('WF11XU')이 후행 공백으로 채워져 테이블의 값과 일치합니다.

의미:

이 패딩은 후행 공백이 포함될 수 있는 정확한 값을 일치시키려고 할 때 문제를 일으킬 수 있습니다. 예를 들어, 의도한 ZoneReference 값이 실제로 후행 공백 없이 'WF11XU'인 경우 쿼리는 결과를 반환하지 않습니다.

해결책:

정확한 일치를 보장하려면, 다음 해결 방법을 고려하십시오.

  • TRIM() 함수를 사용하여 두 문자열 모두에서 후행 공백을 제거합니다. WHERE 절 값 및 테이블 열 값.
  • nvarchar(50)과 같이 후행 공백을 허용하지 않는 데이터 유형으로 문자열을 명시적으로 캐스팅합니다.
  • SQL Server 데이터 정렬 설정 조정 대소문자와 공백을 구분하여 뒤따르는 공백이 무시되는 것을 방지합니다.

위 내용은 SQL Server의 `WHERE` 절은 문자열 비교에서 후행 공백을 무시합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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