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

server/2024/10/18 16:46:02/

        

目录

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/server/4638.html

相关文章

如何把npm切换成yarn管理项目

1.删掉项目中package-lock.json和依赖包 这一步手动删掉就好 2.全局安装yarn npm install -g yarn 3.可以开始执行yarn install安装依赖 1)执行yarn init 这一步是修改npm生成的package.json文件,可能会遇到这个问题: 这个查了一下是有…

Spring AI ETL 流水线

先纠正 Spring AI 使用本地 Ollama Embeddings 中的一个错误,当启动 Ollama 之后,Windows会有托盘图标,此时已经启动了 Ollama 的服务,访问 Embedding 时不需要运行 ollama run gemma ,只有访问 chat 时才需要启动一个…

华为云CodeArts IDE For Python 快速使用指南

CodeArts IDE 带有 Python 扩展,为 Python 语言提供了广泛的支持。Python 扩展可以利用 CodeArts IDE 的代码补全、验证、调试和单元测试等特性,与多种 Python 解释器协同工作,轻松切换包括虚拟环境和 conda 环境的 Python 环境。本文简要概述…

完全平方和的最小次数

完全平方和的最小次数 #include<bits/stdc.h> using namespace std; const int MAXN20; const int INF0x3f3f3f3f; //打印出每一个数的由完全平方数之和组成的最小次数 /*例如当n为10 数字&#xff1a;0 1 2 3 4 5 6 7 8 9 10 结果&#xff1a;0 1 2 3 1 2 3 4 2 1 2 */…

【C语言】字符串转为数值,补充:浮点数、整数、长整数

C语言的标准库stdlib.h中有函数可将字符串转为数值(浮点数、整数、长整数)。 #include <stdlib.h> atof&#xff1a;将字符串转为双精度浮点数&#xff08;类型&#xff1a;double&#xff09;。atoi&#xff1a;将字符串转为整数&#xff08;类型&#xff1a;int&…

【C++】-List经典面试笔试题总结-删除-插入-情况-合并-排序等经典操作

在C中&#xff0c;list 容器是标准模板库&#xff08;STL&#xff09;中的一种双向链表容器。以下是一些关于 list 的经典笔试面试题及解答&#xff1a; 1. list 容器的主要特点是什么&#xff1f; 解答&#xff1a; list 容器的主要特点包括&#xff1a; 它是一个双向链表结…

spring高级篇(二)

1、Aware和InitializingBean Aware和InitializingBean都与Bean的生命周期管理相关。 Aware接口: 概念: Aware接口是Spring框架中的一个标记接口&#xff0c;它表示一个类能够感知到&#xff08;aware of&#xff09;Spring容器的存在及其特定的环境。Spring框架提供了多个Awar…

免费申请泛域名证书

通配符证书是一种比较特殊的SSL/TLS 证书&#xff0c;可用于保护多个域名&#xff08;含主域名&#xff09;&#xff0c;由域名字段中的通配符 (*) 指示。这种证书主要用于具有很多子域的组织。通配符证书对主域及其所有次级子域有效。 对于免费通配符证书而言&#xff0c;目前…