av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Mysql中實(shí)現(xiàn)修改主鍵自增值

瀏覽:13日期:2023-06-08 19:37:37
目錄Mysql修改主鍵自增值重置mysql自增主鍵的值方法總結(jié)Mysql修改主鍵自增值

一般情況下,修改表的主鍵自增值直接運(yùn)行下面的語(yǔ)句,是能成功的。

alter table table_name AUTO_INCREMENT= XX;

但是最近項(xiàng)目遷移數(shù)據(jù)庫(kù),發(fā)覺(jué)有一張表直接運(yùn)行這語(yǔ)句修改自增值不生效,下面就這個(gè)問(wèn)題來(lái)舉例說(shuō)明。

1.首先,我在本地庫(kù)名叫做susunma的庫(kù)下面,新建一張表:

CREATE TABLE `family` (`uid` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增id',`name` varchar(25) NOT NULL COMMENT '姓名',`age` tinyint(4) NOT NULL COMMENT '年齡',PRIMARY KEY (`uid`)) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

2.插入主鍵值不連續(xù)的數(shù)據(jù):

INSERT INTO `family` (`uid`, `name`, `age`)VALUES(1, 'Susunma', 28),(2, 'Winnie', 25),(3, 'Peng', 24),(4, 'Jian', 32),(888, 'Jack', 17),(999, 'Tom', 16);

3.此時(shí)查詢(xún)記錄的最大值以及下一個(gè)自增值

select max(id) from family; ? #999select AUTO_INCREMENT FROM information_schema.tables WHERE table_name='family' and table_schema = 'susunma'; ?#1000

我們會(huì)發(fā)現(xiàn),雖然表里面只有六條數(shù)據(jù),但是由于999記錄的插入,下一個(gè)自增值變成了1000。但是實(shí)際上我們想要下一個(gè)自增值為更小一點(diǎn),比如定為10,因?yàn)橛涗浿衭id為888, 999的情況,實(shí)際上只是項(xiàng)目的要求,為的是使得某個(gè)人的id可以特殊化,下面直接運(yùn)行一下修改自增值的語(yǔ)句:

alter table family AUTO_INCREMENT= 10;

然后再查詢(xún)一下,自增值是否修改成功:

select AUTO_INCREMENT FROM information_schema.tables WHERE table_name='family' and table_schema = 'susunma'; ?#1000

我們會(huì)發(fā)現(xiàn),并沒(méi)有修改成功,下一個(gè)自增值還是1000。所以就在想,難道是修改語(yǔ)句出了問(wèn)題,所以就開(kāi)始很納悶,因?yàn)檎Z(yǔ)句并沒(méi)錯(cuò)。之后,在用不同表調(diào)試間,我們就發(fā)現(xiàn)了:

當(dāng)修改后的自增值大于已有記錄的最大值時(shí),修改語(yǔ)句變得有效,比如,我們把例子中的自增值修改為比記錄中最大值999更大的值2000, 并且查詢(xún)下修改結(jié)果:

alter table family AUTO_INCREMENT=2000;select AUTO_INCREMENT FROM information_schema.tables WHERE table_name='family' and table_schema = 'susunma'; ?#2000

我們會(huì)發(fā)現(xiàn),自增值的確變成了2000。也就是說(shuō)當(dāng)修改后的自增值小于已有記錄的最大值時(shí),修改語(yǔ)句是無(wú)效的。

所以這里采取的解決方案的步驟如下:

1.先將大于10 的uid設(shè)置為比10小的值, 注意這里不要與已有記錄的uid的值重復(fù),因?yàn)橹麈I必須是唯一的:

update family set uid = 9 where uid = 999 limit 1;update family set uid = 8 where uid = 888 limit 1;

2.修改uid的自增值ID為10:

alter table family AUTO_INCREMENT=10;

3.再還原被修改uid的值:

update family set uid = 999 where uid = 9 limit 1;update family set uid = 888 where uid = 8 limit 1;

4.最后查詢(xún)下修改結(jié)果:

select AUTO_INCREMENT FROM information_schema.tables WHERE table_name='family' and table_schema = 'susunma'; ?#10

結(jié)果為10,這樣,就完成了。

重置mysql自增主鍵的值方法show create table [表名]

查看當(dāng)前主鍵索引值

alter table [表名] auto_increment = [你希望的值]

設(shè)置你希望的索引值

切記你希望的索引值一定要大于當(dāng)前表中的最小值

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
主站蜘蛛池模板: 日韩国产欧美在线观看 | 一区二区三区在线免费观看 | 综合久久av | 一本色道精品久久一区二区三区 | 国产精品综合视频 | 久久草在线视频 | 免费在线视频一区二区 | av网站在线播放 | 成人黄色在线观看 | 成人网址在线观看 | 91视频在线观看 | 国产美女视频黄 | 天天艹天天干天天 | 在线成人av | av在线播放免费 | 91日韩在线 | 青青草一区二区三区 | 欧美精品一区二区在线观看 | 五月激情综合网 | 日韩精品久久一区 | 成人中文字幕在线观看 | 亚洲视频免费播放 | 欧美视频1区 | 亚洲精品乱码久久久久久蜜桃91 | 毛片一区二区三区 | 人人做人人澡人人爽欧美 | 理论片免费在线观看 | 国产精品a久久久久 | 亚洲福利视频网 | 五月婷婷导航 | 九九久久国产 | 中文字幕电影在线观看 | 日韩在线播放一区 | 久久久久久国产精品mv | 亚洲区一区二区 | 国产精品三级 | 草草视频在线观看 | 99免费精品视频 | 国产日韩精品一区二区 | 日韩久久久久久久 | 成人不卡在线 |