国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Mysql中實現修改主鍵自增值

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

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

alter table table_name AUTO_INCREMENT= XX;

但是最近項目遷移數據庫,發覺有一張表直接運行這語句修改自增值不生效,下面就這個問題來舉例說明。

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

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.插入主鍵值不連續的數據:

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.此時查詢記錄的最大值以及下一個自增值

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

我們會發現,雖然表里面只有六條數據,但是由于999記錄的插入,下一個自增值變成了1000。但是實際上我們想要下一個自增值為更小一點,比如定為10,因為記錄中uid為888, 999的情況,實際上只是項目的要求,為的是使得某個人的id可以特殊化,下面直接運行一下修改自增值的語句:

alter table family AUTO_INCREMENT= 10;

然后再查詢一下,自增值是否修改成功:

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

我們會發現,并沒有修改成功,下一個自增值還是1000。所以就在想,難道是修改語句出了問題,所以就開始很納悶,因為語句并沒錯。之后,在用不同表調試間,我們就發現了:

當修改后的自增值大于已有記錄的最大值時,修改語句變得有效,比如,我們把例子中的自增值修改為比記錄中最大值999更大的值2000, 并且查詢下修改結果:

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

我們會發現,自增值的確變成了2000。也就是說當修改后的自增值小于已有記錄的最大值時,修改語句是無效的。

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

1.先將大于10 的uid設置為比10小的值, 注意這里不要與已有記錄的uid的值重復,因為主鍵必須是唯一的:

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.最后查詢下修改結果:

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

結果為10,這樣,就完成了。

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

查看當前主鍵索引值

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

設置你希望的索引值

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

總結

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: MySQL 數據庫
主站蜘蛛池模板: 日韩18在线观看 | 亚洲成 人a影院青久在线观看 | 久久在线精品 | 免费看成人毛片 | 成人在线91 | 国产中文字幕免费观看 | 国产精品日本 | 欧美日韩国产高清一区二区三区 | 黄性色 | 亚洲高清视频在线观看 | 欧美日韩国产va另类 | 欧美高清一级毛片免费视 | 暖暖日本在线播放 | 日本三级香港三级三级人 | 国内国语一级毛片在线视频 | 宅男66lu国产乱在线观看 | 99精品免费久久久久久久久日本 | 免费看又黄又爽又猛的网站 | 自拍 第一页 | 九九热国产精品视频 | 中文字幕在线观看网址 | 国产免费高清 | 国产乱子伦露脸对白在线小说 | 欧美片网站免费 | 国产美女精品视频免费观看 | 亚洲国产91 | 泰国情欲片寂寞的寡妇在线观看 | 亚洲视频一区二区在线观看 | 香港日本韩国三级网站 | 免费国产黄网站在线观看视频 | 亚洲线精品一区二区三区 | 国产精品yjizz视频网一二区 | 精品毛片| 一级毛片aaa| 欧美视频在线观看 | 美女张开腿让男人桶爽动漫视频 | 国产午夜精品久久理论片小说 | www欧美在线观看 | aaa级毛片 | 国产精品欧美日韩 | 久久精品国产亚洲麻豆 |