MySQL 문자열을 숫자로 변환하는 미스터리: 'String' = 0이 True를 반환하는 이유
문자열 열을 0과 비교할 때, 놀라운 결과가 발생합니다. 즉, true로 평가됩니다. 이 예상치 못한 동작은 MySQL의 암시적 유형 변환 메커니즘에서 비롯됩니다.
MySQL은 다음 규칙에 따라 자동으로 문자열을 숫자로 변환합니다.
'문자열' = 0의 경우 문자열이 숫자로 시작하지 않으므로 0으로 평가됩니다. 이렇게 변환하면 비교 결과는 '0' = 0이 되며, 이는 사실입니다.
그러나 문자열을 0이 아닌 숫자나 문자열과 비교할 때는 변환이 발생하지 않습니다. 결과적으로 'string' = -12 또는 'string' = '0'은 예상대로 false로 평가됩니다.
이 기본 동작을 재정의하려면 연산자를 사용하여 특정 데이터 유형으로 강제 변환할 수 있습니다. 예를 들어, '0string' 0은 문자열 '0string'을 숫자로 변환하여 '0' = '0' 비교를 유효하게 만듭니다.
이 변환 메커니즘은 숫자가 포함된 문자열에 대해 산술 연산을 수행하는 데에도 사용할 수 있습니다. . 예를 들어, '1abc' '2ef'는 문자열을 숫자로 변환하고 합하여 3이 됩니다.
MySQL 쿼리에서 예상치 못한 결과를 방지하려면 이 유형 변환 동작을 이해하는 것이 중요합니다. 연산자를 활용하여 변환을 명시적으로 제어함으로써 비교 및 계산이 정확한지 확인할 수 있습니다.
위 내용은 MySQL에서 'String' = 0이 True를 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!