欢迎来到小居数码网-一家分享数码知识,生活小常识的网站,希望可以帮助到您。

当前位置:生活小常识 > 数码知识 >
优质

mysql中int和bigint区别(int,smallint,tinyint,bigint)

数码知识

丁颖蕴优秀作者

原创内容 来源:小居数码网 时间:2024-08-16 15:46:01 阅读() 收藏:24 分享:79

导读:您正在阅读的是关于【数码知识】的问题,本文由科普作家协会,生活小能手,著名生活达人等整理监督编写。本文有682个文字,大小约为3KB,预计阅读时间2分钟。

前沿最近做MySQL数据库表设计的时候遇到了多种数字类型的数据,因此对使用哪种数据类型犯难了。以前也没有特别注意这一部分的内容,今天查了一下跟大家共勉。

int,smallint,tinyint,bigint

前沿

mysql中精确的整数数字(是不是有点绕)数据类型主要有bigint,int,smallint和tinyint四种。四种用法和长度各不相同。

一、bigint

存储大小为 8 个字节,长度从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字)。

在myBatis和JPA中生成实体类型为引用类型Long。

对应Java中基本数据类型long,long(长整型)在内存中占64位,即8个字节-2^63~2^63-1,默认值0L(尽量用大写L表示长整型,不要用小写“ l ”,因为在IDE中小写“ l ”和“ 1 ”有点傻傻分不清楚)。

ps: bigint已经有长度了,在mysql建表中的length,只是用于显示的位数。

二、int

存储大小为 4 个字节,长度从 -2^31 (-2,147,483,648) 到 2^31 – 1 (2,147,483,647) 的整型数据(所有数字)。

在myBatis和JPA中生成实体类型为引用类型Integer。

对应Java中基本数据类型int,int(整型)在内在中占32位,即4个字节,取值范围-2147483648~2147483647,默认值0。

三、smallint

存储大小为 2 个字节,从 -2^15 (-32,768) 到 2^15 – 1 (32,767) 的整型数据。

在myBatis和JPA中生成实体类型为引用类型Short。

对应Java中基本数据类型short,short(短整型)在内存中占16位,即2个字节,取值范围-32768~32717,默认值0 。

四、tinyint

存储大小为 1 字节,从 0 到 255 的整型数据。

在myBatis和JPA中生成实体类型为引用类型Byte。

对应Java中基本数据类型byte,byte是Java中最想的数据类型,在内存中占8位(bit),即1个字节,取值范围-128~127,默认值0。

总结

其实细看上面四个类型就会发现一定的规律。bigint,int,smallint和tinyint分别占用8、4、2、1个字节,每个字节占内存8位(bit)。那么他们的长度怎么计算呢?

bigint:从 -2^(8*8 - 1)到2^(8*8-1) - 1;

int:从-2^(4*8 - 1)到2^(4*8-1) - 1;

smallint:从-2^(2*8 - 1)到2^(2*8-1) - 1;

short:从-2^(1*8 - 1) 到2^(1*8-1) - 1;

大家发现规律没有,只要这么一看就很容易记住了各个类型的长度了。

大家请注意每个计算公式最后都 “ -1 ”。这个“ -1 ”是为什么呢,请大家在留言板告诉我。

上面就是小居数码小编今天给大家介绍的关于(int,smallint,tinyint,bigint)的全部内容,希望可以帮助到你,想了解更多关于数码知识的问题,欢迎关注我们,并收藏,转发,分享。

94%的朋友还想知道的:

(334)个朋友认为回复得到帮助。

部分文章信息来源于以及网友投稿,转载请说明出处。

本文标题:mysql中int和bigint区别(int,smallint,tinyint,bigint):http://sjzlt.cn/shuma/156171.html

猜你喜欢