MySQL의 난해한 문자열과 0 비교: Demystified
MySQL 쿼리를 수행할 때 예기치 않은 결과가 발생할 수 있습니다: 문자열 열 비교 0(숫자)을 사용하면 예기치 않게 TRUE가 반환됩니다. 특히 다른 수치 비교에서 예상한 결과가 나올 때 이러한 동작은 직관에 반하는 것처럼 보일 수 있습니다.
MySQL의 기본 메커니즘을 자세히 살펴보면 답은 자동 변환 기능에 있습니다. MySQL은 특정 조건에 따라 문자열을 숫자로 원활하게 변환하는 기능을 보유하고 있습니다.
이 논리를 사용하면 '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 중국어 웹사이트의 기타 관련 기사를 참조하세요!