Computer >> 컴퓨터 >  >> 프로그램 작성 >> MySQL

BIGINT(8)은 MySQL이 저장할 수 있는 가장 큰 정수입니까?

<시간/>

BIGINT(8)에서 숫자 8은 데이터가 표시되는 방식을 나타냅니다. 저장에 영향을 미치지 않습니다. 숫자는 너비를 표시하는 데 사용됩니다.

BIGINT는 8바이트, 즉 64비트를 사용합니다. 부호 있는 범위는 -9223372036854775808 ~ 9223372036854775807이며 부호 없는 범위는 양수 값을 취합니다. unsigned의 범위는 0 ~ 18446744073709551615입니다.

bigint(8)을 이해하기 위해 BIGINT(8) 및 zerofill 열을 사용하여 테이블을 생성하겠습니다 -

mysql> create table BigIntDemo8
   -> (
   -> Number1 BIGINT(8) not null,
   -> Number2 BIGINT(8) unsigned zerofill not null
   -> );
Query OK, 0 rows affected (0.59 sec)

두 열에 대한 일부 레코드를 삽입하십시오. 레코드를 삽입하는 쿼리는 다음과 같습니다 -

mysql> insert into BigIntDemo8 values(1,1);
Query OK, 1 row affected (0.14 sec)

mysql> insert into BigIntDemo8 values(11,11);
Query OK, 1 row affected (0.24 sec)

mysql> insert into BigIntDemo8 values(111,111);
Query OK, 1 row affected (0.14 sec)

mysql> insert into BigIntDemo8 values(1111,1111);
Query OK, 1 row affected (0.18 sec)

mysql> insert into BigIntDemo8 values(11111,11111);
Query OK, 1 row affected (0.10 sec)

mysql> insert into BigIntDemo8 values(111111,111111);
Query OK, 1 row affected (0.21 sec)

select 문을 사용하여 테이블의 모든 레코드를 표시합니다. 쿼리는 다음과 같습니다 -

mysql> select *from BigIntDemo8;

다음은 출력입니다 -

+---------+----------+
| Number1 | Number2  |
+---------+----------+
|       1 | 00000001 |
|      11 | 00000011 |
|     111 | 00000111 |
|    1111 | 00001111 |
|   11111 | 00011111 |
|  111111 | 00111111 |
+---------+----------+
6 rows in set (0.00 sec)