在使用mysql数据库的时候遇到了多种数字的类型,主要有tinyint,smallint,int,bigint这几种类型。
从开发的职场小白到技术大牛,毋庸置疑基本都知道它们最大的区别肯定是长度不同,那么他们有什么区别呢?
1个字符等于8个字节
tinyint
从 -2^7 (-128) 到 2^7 - 1 (123) 的整型数据,unsigned 是从 0 到 2^8 的整型数据,存储大小为 1 字节。
smallint
【mysql中int、bigint、smallint 和 tinyint的区别详细介绍】从 -2^15 (-32,768) 到 2^15 – 1 (32,767) 的整型数据,unsigned 是从 0 到 2^16 的整型数据,存储大小为 2 个字节。
int
从 -2^31 (-2,147,483,648) 到 2^31 – 1 (2,147,483,647) 的整型数据,unsigned 是从 0 到 2^32 的整型数据,存储大小为 4 个字节。
bigint
从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据,unsigned 是从 0 到 2^64 的整型数据,存储大小为 8 个字节。
在支持整数值的地方都可以使用bigint类型的,但不是选择的长度越长越好。就拿人的性别来说,有男女之分,我们完全可以使用tinyint来表示,一个字节就可以搞定了,避免资源的浪费。
一旦数据类型确定好,每个数字在磁盘上占用空间就固定下来,与数值本身大小毫无关系。
推荐阅读
- mysql|InnoDB数据页结构
- javaweb|基于Servlet+jsp+mysql开发javaWeb学生成绩管理系统
- mysql|一文深入理解mysql
- Java毕业设计项目实战篇|Java项目:在线嘿嘿网盘系统设计和实现(java+Springboot+ssm+mysql+maven)
- SQL|SQL基本功(五)--函数、谓词、CASE表达式
- vue|电商后台管理系统(vue+python|node.js)
- Java及基础算法及数据结构|旧笔记整理(MySQL)
- mysql|双非本211硕,无实习无项目,自学大数据开发,秋招上岸
- 数据库|Mysql--InnoDB存储引擎详解
- MySQL学习笔记-9-order by