MySQL自增主键重复问题的可能

MySQL支持数据字段自增,可以用来作为数据表的主键字段。

自增字段的定义和题外话

看一个数据表的创建实例:

DROP TABLE IF EXISTS `spgl_dfxmsplcxxb`;
CREATE TABLE `spgl_dfxmsplcxxb` (
  `LSH` int(11) NOT NULL AUTO_INCREMENT COMMENT '流水号',
  `DFSJZJ` varchar(50) NOT NULL COMMENT '地方数据主键',
  `XZQHDM` varchar(6) NOT NULL COMMENT '行政区划代码',
  `SPLCBM` varchar(100) NOT NULL COMMENT '审批流程编码',
  `SPLCMC` varchar(200) NOT NULL COMMENT '审批流程名称',
  `SPLCBBH` double(4,1) NOT NULL COMMENT '审批流程版本号',
  `SPLCSXSJ` datetime NOT NULL COMMENT '审批流程生效时间',
  `SPLCLX` int(11) NOT NULL COMMENT '审批流程类型',
  `SPLCSM` varchar(2000) DEFAULT NULL COMMENT 'SPLCSM',
  `FJMC` varchar(512) NOT NULL COMMENT '附件名称',
  `FJLX` varchar(64) NOT NULL COMMENT '附件类型',
  `FJID` varchar(100) NOT NULL COMMENT '附件ID',
  `SJYXBS` int(11) NOT NULL COMMENT '数据有效标识',
  `SJWXYY` varchar(200) DEFAULT NULL COMMENT '数据无效原因',
  `SJSCZT` int(11) NOT NULL COMMENT '数据上传状态',
  `SBYY` varchar(1000) DEFAULT NULL COMMENT '失败原因',
  PRIMARY KEY (`LSH`),
  KEY `unique_main` (`XZQHDM`,`SPLCBM`,`SPLCBBH`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8mb4 COMMENT='表1:地方项目审批流程信息表';

该表将LSH字段设置为自增主键,并默认auto_increment_increment=1、auto_increment_offset=1。
对该表执行show create table spgl_dfxmsplcxxb可以得到如下信息:

CREATE TABLE `spgl_dfxmsplcjdxxb` (
  `LSH` int(11) NOT NULL AUTO_INCREMENT COMMENT '流水号',
  `DFSJZJ` varchar(50) NOT NULL COMMENT '地方数据主键',
  `XZQHDM` varchar(6) NOT NULL COMMENT '行政区划代码',
  `SPLCBM` varchar(100) NOT NULL COMMENT '审批流程编码',
  `SPLCBBH` double(4,1) NOT NULL COMMENT '审批流程版本号',
  `SPJDBM` varchar(100) DEFAULT NULL COMMENT '审批阶段编码',
  `SPJDMC` varchar(200) NOT NULL COMMENT '审批阶段名称',
  `SPJDXH` int(11) NOT NULL COMMENT '审批阶段序号',
  `DYBZSPJDXH` varchar(200) NOT NULL COMMENT '对应标准审批阶段序号',
  `SPJDSX` int(11) NOT NULL COMMENT '审批阶段时限',
  `LCBSXLX` int(11) NOT NULL COMMENT '里程碑事项类型',
  `SJYXBS` int(11) NOT NULL COMMENT '数据有效标识',
  `SJWXYY` varchar(200) DEFAULT NULL COMMENT '数据无效原因',
  `SJSCZT` int(11) NOT NULL COMMENT '数据上传状态',
  `SBYY` varchar(1000) DEFAULT NULL COMMENT '失败原因',
  PRIMARY KEY (`LSH`),
  KEY `unique_main` (`XZQHDM`,`SPLCBM`,`SPLCBBH`,`SPJDXH`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='表2:地方项目审批流程阶段信息表'

自增字段重复问题

对于表的记录间互相拷贝问题很容易造成自增字段的重复。
例如在我经历的一次项目:本地数据库和前置数据库进行数据同步时,本地库向前置库上传数据,前置库插入传来的数据并返回自增字段流水号更本地库。同步每3分种依据标志位检查执行一次。这样,如果对本地库数据进行多次修改,那么就需要向前置库多次上传该条记录(或该条记录的拷贝记录)。如果没有在上传前手动将前置库返回的流水号置为空,那么前置库将会用这个已有的流水号作为主键插入新数据(而不是重新生成新的流水号),从而导致主键重复的错误。
所以,在处理含有自增字段的表格时,如果自增字段和其他表格有数据上的关联,应当注意这种操作会不会导致自增字段的冲突。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值