目录
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(无符号)。适用于中等大小的数据。
- INT或INTEGER:占用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. 小数类型
如果你的数字需要支持小数点后的数字,可以考虑以下类型:
- DECIMAL或NUMERIC:固定精度和小数点位置的数字。适用于需要精确表示的场合,如金融数据。你可以指定精度(总位数)和小数位数(小数点后的位数),例如
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)
);