MySQL中使用auto_increment修改初始值和步長
1、如何查看auto_increment的初始值和步長
打開黑窗口,登錄管理員賬號和密碼后,執(zhí)行以下命令:
show variables like 'auto_inc%'; -- 查看當(dāng)前數(shù)據(jù)庫的自增長設(shè)置
執(zhí)行結(jié)果如下:
即 auto_increment的初始值(offset)是1, 步長(increment)是1. (步長指每次的遞增量)。即每次遞增1.
2、如何修改auto_increment的初始值和步長
在黑窗口中執(zhí)行以下命令:
set @@auto_increment_increment=2; --設(shè)置步長為2 set @@auto_increment_offset=2; --設(shè)置初始值為3
接下來做個測試:
--創(chuàng)建測試表test create table test( id int(10) primary key auto_increment, name varchar(50) ); -- 插入測試數(shù)據(jù) insert into test (name) values ('張三'); insert into test (name) values ('李四'); insert into test (name) values ('王五');
我們看下執(zhí)行結(jié)果:
可以看到,修改auto_increment的初始值和步長成功 !
3、auto_increment的問題
這里以 auto_increment的默認(rèn)情況為例(初始值為1,步長為1)
有一種特殊的情況,我們一起看以下示例。
在黑窗口執(zhí)行以下指令:
-- 刪除表test drop table test; -- 創(chuàng)建表test create table test( id int(10) primary key, name varchar(50) ); insert into test values (1,'張三'); insert into test values (3,'李四'); insert into test values (5,'王五');
執(zhí)行結(jié)果如下圖:
接下來,我們?yōu)閠est表的id列添加 auto_increment
alter table test change id tid int(10) auto_increment;
因?yàn)閠est表中的數(shù)據(jù) id 的值時 1、3、5 , 所以我們希望通過修改auto_increment的初始值和步長,來補(bǔ)充中間空缺的id的值,
比如 2、4 ,所以 我們可以修改auto_increment的默認(rèn)設(shè)置。如下指令:
-- 修改auto_increment的初始值和步長 set @@auto_increment_increment=2; --設(shè)置步長為2 set @@auto_increment_offset=2; --設(shè)置初始值
查看修改后的auto_increment相關(guān)信息:
接下來我們再次為test表插入測試數(shù)據(jù):
insert into test (name) values ('薛之謙'); insert into test (name) values ('毛不易'); insert into test (name) values ('鄧紫棋');
查詢下最終的結(jié)果:
大家發(fā)現(xiàn),并不是我們想要的結(jié)果。其實(shí)auto_increment在使用時,會對初始值與添加了auto_increment語法的列中的值進(jìn)行比較,當(dāng) auto_increment的當(dāng)前值(此處值是2)小于 添加了該語法的列的值時,auto_increment會拿當(dāng)前值2 根據(jù)步長(2)遞增,知道auto_increment的當(dāng)前值大于添加了該語法的列(id)的值時,才會將最終的這個值作為初始插入數(shù)據(jù)的值。也就是說,執(zhí)行以下流程:
auto_increment 初始值 2 步長2
插入第一條數(shù)據(jù) '薛之謙 ' 時,會拿2跟表中數(shù)據(jù)的id的值進(jìn)行比較
2>1
2<3 auto_increment 此時會遞增一次,遞增后的結(jié)果是4
4>3
4<5 auto_increment 此時會繼續(xù)遞增一次,遞增后的值是6
6>5
此時表中已經(jīng)沒有其他的數(shù)據(jù),6最大,此時才執(zhí)行插入 第一條數(shù)據(jù) '薛之謙',因此,'薛之謙' 的 id = 6,
因?yàn)椴介L是2,所以后面id的值依是 id = 8 ,id= 10 . 所以才會發(fā)生剛剛大家的那種情況。
auto_increment 在插入數(shù)據(jù)時,真正一開始可以插入表中的值得計(jì)算公式:
假設(shè) a 為 表中id列的最大值, b為auto_increment的初始值,c 為步長,則auto_increment真正的初始值為:
auto_increment_real = int( a/b) * c + c ;
即 auto_increment_real =(5 % 2)*2 + 2 = 6
參考mysql官方文檔地址:官方文檔在此,公式出自此處
到此這篇關(guān)于MySQL中使用auto_increment修改初始值和步長的文章就介紹到這了,更多相關(guān)MySQL修改初始值和步長內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Navicat配置mysql數(shù)據(jù)庫用戶權(quán)限問題
這篇文章主要介紹了Navicat配置mysql數(shù)據(jù)庫用戶權(quán)限問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03Mysql寫入數(shù)據(jù)十幾秒后被自動刪除了如何解決
這篇文章主要介紹了Mysql寫入數(shù)據(jù)十幾秒后被自動刪除了如何解決,文章通過圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-09-09MySQL分組查詢獲取每組最新的一條數(shù)據(jù)詳解(group?by)
在寫報表功能時遇到一個需要根據(jù)用戶id分組查詢最新一條錢包明細(xì)數(shù)據(jù)的需求,下面這篇文章主要給大家介紹了關(guān)于MySQL分組查詢獲取每組最新的一條數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2024-08-08