码迷,mamicode.com
首页 > 数据库 > 详细

mysql insert操作失败后id 在auto_increment下仍会自增的解决办法

时间:2020-01-27 15:47:20      阅读:209      评论:0      收藏:0      [点我收藏+]

标签:情况   increase   record   unique   插入数据   constrain   ima   har   insert   

在使用golang go-sql-driver操作mysql时,往tag表插入一条新数据时,如果插入失败,id仍会自增,插入数据失败次数过多时,id就看起来十分混乱。
所以我就在搜索下原因,发现是InnoDB的机制,大致就是说InnoDB的innodb_autoinc_lock_mode模式下,自增计数器在操作失败的情况下仍会增加。一般情况下如果担心id增加超过范围,可以把id的类型改为BIGINT。

create table tag
(
    id     int auto_increment primary key,
    gender int         null,
    name   varchar(50) null,
    constraint tag_name_gender_uindex
        unique (name, gender)
)ENGINE=InnoDB;

插入一条记录

常规写法:

insert ignore into tag (name,gender) values ('anime',2);

ignore 是为了插入失败时不报错。
修改的写法:

insert ignore into tag (name,gender) 
select * from (SELECT 'anime',2) AS tmp 
where not exists (
    select * from tag where name='anime' AND gender=2
);

参考文章:

mysql insert操作失败后id 在auto_increment下仍会自增的解决办法

标签:情况   increase   record   unique   插入数据   constrain   ima   har   insert   

原文地址:https://www.cnblogs.com/waterserver/p/12236049.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!