SQL WHERE 절: 값 일치의 후행 공백
SQL Server에서 WHERE 절을 사용한 문자열 비교는 다음과 같은 특이한 동작을 나타냅니다. 예상치 못한 결과에. 특히 항등 연산자(=)는 비교를 수행할 때 후행 공백을 무시합니다.
다음 시나리오를 고려하십시오.
select '"' + ZoneReference + '"' as QuotedZoneReference from Zone where ZoneReference = 'WF11XU'
놀랍게도 쿼리는 다음 결과를 반환합니다.
"WF11XU "
설명:
이것은 동작은 비교 작업의 문자열을 다음으로 채워야 함을 지시하는 SQL-92 사양에서 비롯됩니다. 비교하기 전에 길이가 같은지 확인하십시오. 이 경우 WHERE 절의 ZoneReference 값('WF11XU')이 후행 공백으로 채워져 테이블의 값과 일치합니다.
의미:
이 패딩은 후행 공백이 포함될 수 있는 정확한 값을 일치시키려고 할 때 문제를 일으킬 수 있습니다. 예를 들어, 의도한 ZoneReference 값이 실제로 후행 공백 없이 'WF11XU'인 경우 쿼리는 결과를 반환하지 않습니다.
해결책:
정확한 일치를 보장하려면, 다음 해결 방법을 고려하십시오.
위 내용은 SQL Server의 `WHERE` 절은 문자열 비교에서 후행 공백을 무시합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!