【Mysql】mysql表设计时字段类型的选择建议

ops/2024/11/19 21:30:14/

        

目录

1. 整数类型

2. 小数类型

选择建议

例子


在 MySQL 中设计表时选择字段的数据类型,特别是当你知道该字段的值将仅包含数字时,你应根据数据的性质和范围来选择最适合的类型。以下是几种常见的数字类型及其适用场景:

1. 整数类型

  • TINYINT:占用1个字节,范围从-128到127,或者0到255(无符号)。适用于非常小的数据,如年龄、数量。
  • SMALLINT:占用2个字节,范围从-32,768到32,767,或者0到65,535(无符号)。适用于较小的数据,如分数、小型计数器。
  • MEDIUMINT:占用3个字节,范围从-8,388,608到8,388,607,或者0到16,777,215(无符号)。适用于中等大小的数据。
  • INTINTEGER:占用4个字节,范围从-2,147,483,648到2,147,483,647,或者0到4,294,967,295(无符号)。适用于大多数常规应用,如用户ID、产品ID。
  • BIGINT:占用8个字节,范围从-9,223,372,036,854,775,808到9,223,372,036,854,775,807,或者0到18,446,744,073,709,551,615(无符号)。适用于非常大的数值,如社会安全号、大型计数器。

2. 小数类型

如果你的数字需要支持小数点后的数字,可以考虑以下类型:

  • DECIMALNUMERIC:固定精度和小数点位置的数字。适用于需要精确表示的场合,如金融数据。你可以指定精度(总位数)和小数位数(小数点后的位数),例如DECIMAL(10,2)
  • FLOAT:单精度浮点数,适用于不需要完全精确的大范围浮点数。
  • DOUBLE:双精度浮点数,适用于更大范围和精度要求稍高的场景。

选择建议

  • 如果你确定字段只会包含整数并且范围有限,可以选择一个适当的整数类型(如TINYINT, SMALLINT, INT等)。
  • 如果数字的精确度非常关键,应选择DECIMAL
  • 考虑使用无符号(UNSIGNED)属性,如果你知道数字永远不会是负数,这可以加倍你的正数范围。

例子

假设你在设计一个系统,需要存储一个标准的用户ID,预计用户数量不会超过一亿,你可以选择使用INT UNSIGNED

CREATE TABLE users (user_id INT UNSIGNED NOT NULL AUTO_INCREMENT,username VARCHAR(50) NOT NULL,PRIMARY KEY (user_id)
);


http://www.ppmy.cn/ops/17258.html

相关文章

数仓开发LAG 和 LEAD 函数详细解析和用例

在做Iot大数据开发时,需要用到lag和lead函数来计算设备故障。下面详细解析lag和lead函数的作用和例子。 LAG 和 LEAD 函数是用于在 Spark SQL 中进行窗口函数操作时常用的两个函数,它们用于获取某一行在分组内的前一行或后一行的数值。下面详细解释它们…

基于spring boot开发的快递管理系统开题报告

快递公司管理系统开题报告 一、研究背景与意义 随着电子商务的蓬勃发展,快递物流行业迎来了前所未有的增长机遇。然而,快递公司在面对日益增长的业务量时,也面临着管理效率低下、资源分配不合理、客户服务体验不佳等问题。开发一套高效、智…

Golang | Leetcode Golang题解之第50题Pow(x,n)

题目: 题解: func myPow(x float64, n int) float64 {if n > 0 {return quickMul(x, n)}return 1.0 / quickMul(x, -n) }func quickMul(x float64, n int) float64 {if n 0 {return 1}y : quickMul(x, n/2)if n%2 0 {return y * y}return y * y * …

WPF —— lCommand命令实例

首先在标签页面设置一个Button按钮 <Button Width"100" Height"40" Content"测试" ></Button> 1 创建一个类 继承于ICommand这个接口&#xff0c; 这个接口一般包含三部分&#xff1a; 俩个方法&#xff1a;一个判断指令是不是…

微信小程序开发之多图片上传+.NET WebAPI后端服务保存图片资源

前言&#xff1a; 最近开发的一个微信小程序项目需要做一个同时选中三张&#xff08;或者是多张&#xff09;图片一起上传到服务端&#xff0c;服务端保存图片资源并保存的功能。发现在微信小程序开发中会有很多场景会使用到多图片上传并保存到的功能&#xff0c;所以我把自己总…

软考 系统架构设计师系列知识点之大数据设计理论与实践(13)

接前一篇文章&#xff1a;软考 系统架构设计师系列知识点之大数据设计理论与实践&#xff08;12&#xff09; 所属章节&#xff1a; 第19章. 大数据架构设计理论与实践 第4节 Kappa架构 19.4.2 Kappa架构介绍 Kappa架构由Jay Kreps提出&#xff08;Lambda由Storm之父Nayhan M…

ARM之栈与方法

ARM之栈与方法 计算机中的栈是一种线性表&#xff0c;它被限定只能在一端进行插入和删除操作&#xff08;先进后出&#xff09;。通常将可以插入和删除操作的一端称为栈顶&#xff0c;相对的一端为栈底。 通常栈有递增堆栈&#xff08;向高地址方向生长&#xff09;、递减堆栈…

水电气能耗管理云平台

安科瑞薛瑶瑶18701709087/17343930412 能耗管理云平台采用泛在物联、云计算、大数据、移动通讯、智能传感器等技术手段可为用户提供能源数据采集、统计分析、能效分析、用能预警、设备管理等服务&#xff0c;平台可以广泛应用于多种领域。