MySQL 정수 열에 허용된 최대값보다 큰 숫자를 삽입하면 어떻게 되나요?

Mary-Kate Olsen
풀어 주다: 2024-10-31 09:26:01
원래의
282명이 탐색했습니다.

What Happens When You Insert a Number Larger than the Maximum Value Allowed in a MySQL Integer Column?

MySQL의 정수 오버플로: 긴 정수 변환 이해

MySQL에서 길이가 부족한 열에 지나치게 큰 정수를 삽입하면 오류가 발생할 수 있습니다. 뜻밖의 변신. 잘림과 달리 이 현상은 정수를 열의 데이터 유형으로 표현할 수 있는 최대값으로 변환하는 것과 관련됩니다.

설명을 위해 길이가 10이고 정수를 보유할 수 있는 some_number라는 열을 생각해 보겠습니다. 최대 2147483647(32비트 부호 있는 정수의 최대값)입니다. 이 열에 715988985123857과 같은 숫자를 삽입하면 데이터베이스의 결과는 2147483647로 나타납니다.

이러한 변환은 MySQL이 정수 오버플로에 대해 다음 동작을 준수하기 때문에 발생합니다.

  • If 삽입된 값이 데이터 유형의 최대값을 초과하면 정수가 순환되어 최대값으로 재설정됩니다.

이 경우 715988985123857은 2147483647보다 훨씬 큽니다. 따라서 최대값은 2147483647입니다.

공식:

오버플로 후 결과 숫자를 결정하는 공식은 다음과 같이 표현될 수 있습니다.

Result = (Input Integer - Minimum Integer for DataType) % (Maximum Integer for DataType - Minimum Integer for DataType) + Minimum Integer for DataType
로그인 후 복사

주어진 예에서 결과는 다음과 같이 계산될 수 있습니다.

Result = (715988985123857 - -2147483648) % (2147483647 - -2147483648) + -2147483648
= 2147483647
로그인 후 복사

정수 오버플로의 메커니즘을 이해하면 예기치 않은 값이 데이터베이스에 저장되는 것을 방지할 수 있습니다. 이 지식은 지정된 데이터 유형의 제한을 초과할 수 있는 정수로 작업할 때 특히 중요합니다.

위 내용은 MySQL 정수 열에 허용된 최대값보다 큰 숫자를 삽입하면 어떻게 되나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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