MySQL에서 \'String\' = 0이 True를 반환하는 이유는 무엇입니까?

Linda Hamilton
풀어 주다: 2024-11-24 05:58:18
원래의
268명이 탐색했습니다.

Why Does 'String' = 0 Return True in MySQL?

MySQL 문자열을 숫자로 변환하는 미스터리: 'String' = 0이 True를 반환하는 이유

문자열 열을 0과 비교할 때, 놀라운 결과가 발생합니다. 즉, true로 평가됩니다. 이 예상치 못한 동작은 MySQL의 암시적 유형 변환 메커니즘에서 비롯됩니다.

MySQL은 다음 규칙에 따라 자동으로 문자열을 숫자로 변환합니다.

  • 문자열이 숫자로 시작하면 숫자로 변환됩니다.
  • 문자열이 숫자로 시작하지 않으면 다음과 같이 처리됩니다. 0.

'문자열' = 0의 경우 문자열이 숫자로 시작하지 않으므로 0으로 평가됩니다. 이렇게 변환하면 비교 결과는 '0' = 0이 되며, 이는 사실입니다.

그러나 문자열을 0이 아닌 숫자나 문자열과 비교할 때는 변환이 발생하지 않습니다. 결과적으로 'string' = -12 또는 'string' = '0'은 예상대로 false로 평가됩니다.

이 기본 동작을 재정의하려면 연산자를 사용하여 특정 데이터 유형으로 강제 변환할 수 있습니다. 예를 들어, '0string' 0은 문자열 '0string'을 숫자로 변환하여 '0' = '0' 비교를 유효하게 만듭니다.

이 변환 메커니즘은 숫자가 포함된 문자열에 대해 산술 연산을 수행하는 데에도 사용할 수 있습니다. . 예를 들어, '1abc' '2ef'는 문자열을 숫자로 변환하고 합하여 3이 됩니다.

MySQL 쿼리에서 예상치 못한 결과를 방지하려면 이 유형 변환 동작을 이해하는 것이 중요합니다. 연산자를 활용하여 변환을 명시적으로 제어함으로써 비교 및 ​​계산이 정확한지 확인할 수 있습니다.

위 내용은 MySQL에서 \'String\' = 0이 True를 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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