欢迎光临护送网
详情描述

BIGINTBIGINT(20)作为主键自增字段的主要区别在于显示宽度,而非存储大小或范围。下面是详细解析:

1. 核心区别:显示宽度

BIGINT

  • 默认显示宽度为21位(符号位+20位数字)
  • 实际存储范围:-9,223,372,036,854,775,808 到 9,223,372,036,854,775,807

BIGINT(20)

  • 指定显示宽度为20位
  • 注意:括号中的数字只是显示宽度,不是最大值限制
  • 实际存储范围与普通BIGINT完全相同

2. 存储特性相同

-- 两种定义方式在存储上完全一样
CREATE TABLE t1 (
    id BIGINT AUTO_INCREMENT PRIMARY KEY
);

CREATE TABLE t2 (
    id BIGINT(20) AUTO_INCREMENT PRIMARY KEY
);

-- 两者都占用8字节存储空间
-- 两者都有相同的自增范围

3. 显示宽度的影响

在非ZEROFILL情况下

  • 显示宽度基本没有影响
  • MySQL客户端可能用指定宽度格式化输出,但不会截断数据
-- 创建一个测试表
CREATE TABLE test_table (
    id BIGINT(5) AUTO_INCREMENT PRIMARY KEY,
    value VARCHAR(10)
);

-- 插入超过显示宽度的值
INSERT INTO test_table (value) VALUES ('test');
INSERT INTO test_table (value) VALUES ('test');
-- id会正常自增为1, 2... 即使显示宽度设为5,也能存储很大的数

在ZEROFILL情况下

显示宽度才有实际意义:

CREATE TABLE zerofill_test (
    id BIGINT(10) ZEROFILL AUTO_INCREMENT PRIMARY KEY
);

-- 插入数据
INSERT INTO zerofill_test VALUES (1), (123), (123456);

-- 查询结果会自动补零到10位:
-- 0000000001
-- 0000000123
-- 0000123456

4. 实际建议

推荐使用 BIGINT(不带宽度)

CREATE TABLE users (
    id BIGINT AUTO_INCREMENT PRIMARY KEY,
    -- 其他字段...
);

原因:

简洁明了:去掉不必要的显示宽度声明 避免误解BIGINT(20)容易被误解为最大值限制 兼容性:在ORM框架中更清晰 ZEROFILL已弃用:MySQL 8.0+中ZEROFILL属性已被弃用

5. 自增主键的最佳实践

-- 最佳实践示例
CREATE TABLE orders (
    id BIGINT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
    -- 使用UNSIGNED将范围翻倍:0 ~ 18,446,744,073,709,551,615
    -- 这对于自增主键非常合适
    order_no VARCHAR(32) NOT NULL UNIQUE,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
) AUTO_INCREMENT = 100000;  -- 可以设置起始值

-- 或者使用更通用的方式
CREATE TABLE products (
    id BIGINT AUTO_INCREMENT PRIMARY KEY,
    product_code VARCHAR(50) NOT NULL UNIQUE
);

6. 重要注意事项

自增溢出

-- 当达到最大值时,继续插入会报错
-- 2147483647 (INT最大值) 或 9223372036854775807 (BIGINT最大值)

复制环境

  • 在MySQL复制中,自增值的步长可能需要特殊配置
  • 使用auto_increment_incrementauto_increment_offset控制

分库分表考虑

-- 在分布式系统中,可能需要使用特定算法生成ID
-- 而不是依赖数据库自增

总结

特性 BIGINT BIGINT(20)
存储大小 8字节 8字节
存储范围 -2^63 ~ 2^63-1 -2^63 ~ 2^63-1
显示宽度 默认(21) 指定(20)
实际影响 无功能区别 仅影响显示格式
推荐程度 ✅ 推荐 ⚠️ 不必要

结论:对于自增主键,建议使用BIGINT UNSIGNED AUTO_INCREMENT PRIMARY KEY,显示宽度参数可以省略,因为它不影响实际存储和功能。

相关帖子
了解眼睛的调节机制,能帮助我们更好地理解假性近视为何有可能恢复吗?
了解眼睛的调节机制,能帮助我们更好地理解假性近视为何有可能恢复吗?
阜阳市120救护车接送患者转院-设备齐全,收费合理
阜阳市120救护车接送患者转院-设备齐全,收费合理
阜阳市精准获客#品牌网站建设,高端网站开发设计
阜阳市精准获客#品牌网站建设,高端网站开发设计
从新手到专家,掌握一项职业技能通常需要哪些步骤?
从新手到专家,掌握一项职业技能通常需要哪些步骤?
阜阳市120救护车跨省转院-长途120救护车护送,转院接送
阜阳市120救护车跨省转院-长途120救护车护送,转院接送
2026年老年公交卡政策还在继续执行吗,各地关于老年人免费乘车的规则有哪些新变化?
2026年老年公交卡政策还在继续执行吗,各地关于老年人免费乘车的规则有哪些新变化?
2026年,企业更看重继续教育带来的软技能提升还是硬技能认证?
2026年,企业更看重继续教育带来的软技能提升还是硬技能认证?
黄金贷款合同签订技巧,读懂条款知识明确借贷双方权利义务
黄金贷款合同签订技巧,读懂条款知识明确借贷双方权利义务
用人单位对于“三期”女职工的工作量安排,应当遵循怎样的合理性原则?
用人单位对于“三期”女职工的工作量安排,应当遵循怎样的合理性原则?
安顺市长途救护车出租转运病人-24小时随叫随到
安顺市长途救护车出租转运病人-24小时随叫随到
台州市精准获客助手@网站制作设计服务,多年专业建站经验
台州市精准获客助手@网站制作设计服务,多年专业建站经验
物业公司提出的维修基金使用方案,业主们应该重点审核哪些内容?
物业公司提出的维修基金使用方案,业主们应该重点审核哪些内容?
珠海市电商网站建设#商城网站开发,企业解决方案
珠海市电商网站建设#商城网站开发,企业解决方案
齐齐哈尔市120救护车跨省护送病人回家-长途跨省救护车转运24小时电话
齐齐哈尔市120救护车跨省护送病人回家-长途跨省救护车转运24小时电话
舟山市营销网站建设@独立网站制作,价格透明
舟山市营销网站建设@独立网站制作,价格透明
母婴室从“有没有”到“好不好用”的转变,反映了怎样的社会观念进步?
母婴室从“有没有”到“好不好用”的转变,反映了怎样的社会观念进步?
关于单用途商业预付卡的管理办法,在2026年是否有重要的调整和变化?
关于单用途商业预付卡的管理办法,在2026年是否有重要的调整和变化?
开封市苹果手机app开发#模版网站开发设计,一站式建站服务
开封市苹果手机app开发#模版网站开发设计,一站式建站服务
除了卫生巾和棉条,2026年还有哪些创新产品在改变月经护理方式?
除了卫生巾和棉条,2026年还有哪些创新产品在改变月经护理方式?
房抵贷的房产评估价怎么定?和市场价差多少你心里要有数
房抵贷的房产评估价怎么定?和市场价差多少你心里要有数