這篇文章主要介紹“MySQL中的自增主鍵為什么不是連續(xù)的”,在日常操作中,相信很多人在mysql中的自增主鍵為什么不是連續(xù)的問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”mysql中的自增主鍵為什么不是連續(xù)的”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!
創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比白塔網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式白塔網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋白塔地區(qū)。費(fèi)用合理售后完善,十余年實(shí)體公司更值得信賴。
1 自增主鍵不能保證連續(xù)遞增
2 MYSQL 5.7之前版本,自增值保存在內(nèi)存里,沒(méi)有持久化,重啟后會(huì)拿當(dāng)前max(id)+1作為最新主鍵;8版本,將自增值的變更記錄在redo log中,重啟的時(shí)候依靠redo log恢復(fù)重啟之前的值
3自增值修改機(jī)制
3.1如果插入數(shù)據(jù)時(shí)id字段指定為0,null,或者未指定值,那么就把這個(gè)表當(dāng)前auto_increment值添加到自增字段
3.2如果id字段指定了具體的值,就直接使用語(yǔ)句里指定值
3.3根據(jù)插入值和當(dāng)前自增值大小關(guān)系,自增值變更結(jié)果也會(huì)有所不同,某次要插入值是X,當(dāng)前自增值是Y
1.如果X 2.如果X>=Y,就要把當(dāng)前自增值修改為新自增值 重要的兩個(gè)參數(shù) 自增初始值和步長(zhǎng),默認(rèn)都是1 原因: 1唯一健沖突是導(dǎo)致自增主鍵id不連續(xù)的第一種原因 2事務(wù)回滾也會(huì)造成主鍵id不連續(xù) 3批量插入時(shí),批量申請(qǐng)主鍵id,沒(méi)有用完,導(dǎo)致主鍵id不連續(xù) eg: CREATE TABLE `t` ( insert into t values(null, 1,1); 到此,關(guān)于“mysql中的自增主鍵為什么不是連續(xù)的”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!
`id` int(11) NOT NULL AUTO_INCREMENT,
`c` int(11) DEFAULT NULL,
`d` int(11) DEFAULT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `c` (`c`)
) ENGINE=InnoDB
insert into t values(null, 2,2);
insert into t values(null, 3,3);
insert into t values(null, 4,4);
create table t2 like t;
insert into t2(c,d) select c,d from t;
insert into t2 values(null, 5,5);
文章題目:mysql中的自增主鍵為什么不是連續(xù)的
新聞來(lái)源:http://weahome.cn/article/iediic.html