MySQL은 어떻게 쿼리에서 문자열을 숫자로 자동 변환합니까?

Patricia Arquette
풀어 주다: 2024-11-17 17:07:02
원래의
442명이 탐색했습니다.

How Does MySQL Automatically Convert Strings to Numbers in Queries?

MySQL의 자동 문자열-숫자 변환 이해

MySQL은 문자열 및 숫자 값으로 작업할 때 고유한 동작을 나타냅니다. 특정 시나리오에서는 자동으로 문자열을 숫자 대응으로 변환하여 이 변환이 어떻게 발생하는지에 대한 흥미로운 질문을 제기합니다.

자동 변환 규칙

MySQL은 자동 문자열 변환에 대한 특정 규칙을 따릅니다. :

  • 숫자만 포함하는 문자열(예: '1234')은 해당 숫자 값(1234)으로 변환됩니다.
  • 숫자와 숫자가 아닌 문자가 모두 포함된 문자열(예: ' 1abc')는 접두사 숫자 값(1)으로 변환됩니다.
  • 숫자가 아닌 문자(예: 'text')만 포함하는 문자열은 0으로 변환됩니다.

쿼리의 적용

다음 쿼리를 고려하십시오.

SELECT table.* 
FROM table 
WHERE>
로그인 후 복사

id 열이 bigint 데이터 유형인 경우. 쿼리는 id 열이 문자열 'text'와 일치하는 행을 검색합니다.

변환 규칙에 따라 'text'는 0으로 변환됩니다. 따라서 쿼리는 사실상 다음과 같습니다.

WHERE id = 0.0
로그인 후 복사

이것은 숫자가 아닌 문자열에 대한 MySQL의 평가를 실수로 강조하여 부동 소수점과 비교합니다(따라서 '텍스트'는 0.0으로 해석됨).

추가 정보

이 주제에 대한 자세한 내용은 [문서 링크]에서 유형 변환에 대한 공식 MySQL 문서를 참조하세요.

위 내용은 MySQL은 어떻게 쿼리에서 문자열을 숫자로 자동 변환합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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