>  기사  >  데이터 베이스  >  MySQL INT 열에 삽입되면 큰 정수 값이 2147483647로 변환되는 이유는 무엇입니까?

MySQL INT 열에 삽입되면 큰 정수 값이 2147483647로 변환되는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-01 09:57:02778검색

Why Does a Large Integer Value Transform into 2147483647 When Inserted into a MySQL INT Column?

정수 잘림 불일치 이해

다음과 같이 길이가 10인 정수 열이 있는 상황을 생각해 보세요.

<code class="sql">`some_number` int(10) unsigned NOT NULL</code>

열의 허용 범위보다 큰 값을 삽입하는 경우:

<code class="php">$some_number = 715988985123857;
$query = "INSERT INTO this_table SET some_number = ?";
$stmt = $mysqli->prepare($query);
$stmt->bind_param('i', $some_number);
$stmt->execute();</code>

잘림이 발생하여 값이 더 짧아질 것으로 예상할 수 있습니다. 그러나 놀랍게도 테이블의 값은 2147483647로 변환됩니다.

변환의 메커니즘

MySQL 문서에 따르면 int 및 정수 유형에 대한 정수 오버플로는 다음과 같은 결과를 낳습니다. 허용되는 최대 수는 2147483647입니다. 이 동작은 잘림이 아니라 원래 값의 나머지 부분을 허용되는 최대 수로 나누는 모듈로 연산입니다.

계산 공식

정수 오버플로 결과를 계산하려면 다음 공식을 사용하세요.

result = original_value % maximum_allowed_value

이 경우:

result = 715988985123857 % 2147483647 = 2147483647

따라서 큰 값은 정수 오버플로 및 모듈로 연산으로 인해 데이터베이스에서 715988985123857은 2147483647이 됩니다.

위 내용은 MySQL INT 열에 삽입되면 큰 정수 값이 2147483647로 변환되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.