目录

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)
);