> 데이터 베이스 > MySQL 튜토리얼 > MySQL의 0과 문자열 비교가 때때로 TRUE를 반환하는 이유는 무엇입니까?

MySQL의 0과 문자열 비교가 때때로 TRUE를 반환하는 이유는 무엇입니까?

Patricia Arquette
풀어 주다: 2024-11-26 04:24:14
원래의
873명이 탐색했습니다.

Why Does MySQL's String Comparison with 0 Sometimes Return TRUE?

MySQL의 난해한 문자열과 0 비교: Demystified

MySQL 쿼리를 수행할 때 예기치 않은 결과가 발생할 수 있습니다: 문자열 열 비교 0(숫자)을 사용하면 예기치 않게 TRUE가 반환됩니다. 특히 다른 수치 비교에서 예상한 결과가 나올 때 이러한 동작은 직관에 반하는 것처럼 보일 수 있습니다.

MySQL의 기본 메커니즘을 자세히 살펴보면 답은 자동 변환 기능에 있습니다. MySQL은 특정 조건에 따라 문자열을 숫자로 원활하게 변환하는 기능을 보유하고 있습니다.

  • 숫자로 시작하는 문자열은 숫자로 해석됩니다.
  • 앞에 숫자 문자가 없는 문자열은 0으로 평가됩니다.

이 논리를 사용하면 'string' = 0이 TRUE를 반환하는 미스터리를 풀 수 있습니다. '문자열'은 숫자로 시작하지 않기 때문에 MySQL은 이를 0으로 해석하여 SELECT 0 = 0 비교 결과를 내며 이는 물론 TRUE로 평가됩니다.

그러나 이러한 변환은 다음과 같다는 점에 유의하는 것이 중요합니다. 문자열을 직접 비교할 때는 발생하지 않습니다. 예를 들어, '0string' = 'string'은 의도한 대로 FALSE를 생성합니다.

또는 연산자(예: )를 사용하여 명시적으로 변환하면 MySQL이 문자열을 숫자로 처리하게 됩니다. ' ' 연산자를 사용할 때 MySQL은 '0string'과 0을 합산하여 두 값을 숫자(0 0)로 변환하여 예상되는 TRUE 값을 얻습니다.

게다가 MySQL은 숫자 문자가 포함된 문자열 합산도 허용합니다. 예를 들어, '1abc' '2ef'는 사실상 1 2로 변환되어 예상되는 결과 3을 생성합니다.

이러한 숨은 메커니즘을 이해하면 MySQL의 문자열 대 0 비교의 수수께끼를 풀 수 있습니다. 정확한 데이터 해석과 정확한 쿼리 구성.

위 내용은 MySQL의 0과 문자열 비교가 때때로 TRUE를 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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