欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2023年07月14日 09:57:01   作者:清音Susunma  
這篇文章主要介紹了Mysql中實現(xiàn)修改主鍵自增值方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Mysql修改主鍵自增值

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

alter table table_name AUTO_INCREMENT= XX;

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

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.插入主鍵值不連續(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.此時查詢記錄的最大值以及下一個自增值

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

我們會發(fā)現(xiàn),雖然表里面只有六條數(shù)據(jù),但是由于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

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

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

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

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

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

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

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.最后查詢下修改結(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é)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • MySQL不用like+%實現(xiàn)模糊查詢

    MySQL不用like+%實現(xiàn)模糊查詢

    本文主要介紹了MySQL不用like+%實現(xiàn)模糊查詢,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • MySQL存儲表情符號小技巧

    MySQL存儲表情符號小技巧

    這篇文章主要為大家介紹了MySQL如何存儲表情符號的小技巧,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2024-01-01
  • MySQL中給自定義的字段查詢結(jié)果添加排名的方法

    MySQL中給自定義的字段查詢結(jié)果添加排名的方法

    這篇文章主要介紹了MySQL中給自定義的字段查詢結(jié)果添加排名的方法,只需要對counter寫一個小算式,非常簡單,需要的朋友可以參考下
    2015-06-06
  • mysql 8.0.15 winx64解壓版圖文安裝教程

    mysql 8.0.15 winx64解壓版圖文安裝教程

    這篇文章主要為大家詳細(xì)介紹了mysql 8.0.15 winx64解壓版圖文安裝教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • Mysql MVCC多版本并發(fā)控制詳情

    Mysql MVCC多版本并發(fā)控制詳情

    這篇文章主要介紹了Mysql MVCC多版本并發(fā)控制詳情,MVCC是一種并發(fā)控制的方法,一般在數(shù)據(jù)庫管理系統(tǒng)中,實現(xiàn)對數(shù)據(jù)庫的并發(fā)訪問,在編程語言中實現(xiàn)事務(wù)內(nèi)存,下文更多相關(guān)介紹需要的小伙伴可以參考一下
    2022-04-04
  • mysql 循環(huán)批量插入的實例代碼詳解

    mysql 循環(huán)批量插入的實例代碼詳解

    本文通過實例代碼文字相結(jié)合的形式給大家介紹了mysql 循環(huán)批量插入功能,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • MySQL 處理插入過程中的主鍵唯一鍵重復(fù)值的解決方法

    MySQL 處理插入過程中的主鍵唯一鍵重復(fù)值的解決方法

    本篇文章主要介紹在插入數(shù)據(jù)到表中遇到鍵重復(fù)避免插入重復(fù)值的處理方法,主要涉及到IGNORE,ON DUPLICATE KEY UPDATE,REPLACE的相關(guān)知識,感興趣的朋友一起學(xué)習(xí)吧
    2016-04-04
  • MySQL的存儲引擎InnoDB和MyISAM

    MySQL的存儲引擎InnoDB和MyISAM

    這篇文章主要介紹了MySQL的存儲引擎InnoDB和MyISAM,MyISAM?用的是非聚集索引方式,即數(shù)據(jù)和索引落在不同的兩個文件上,下文更多相關(guān)內(nèi)容需要的小伙伴可以參考一下
    2022-04-04
  • 關(guān)于Mysql的InnoDB鎖概述

    關(guān)于Mysql的InnoDB鎖概述

    這篇文章主要介紹了關(guān)于Mysql的InnoDB鎖概述,對于更新操作(UPDATE、INSERT、DELETE),InnoDB會自動給涉及到的數(shù)據(jù)集加排他鎖,需要的朋友可以參考下
    2023-05-05
  • 使用SQL查詢所有數(shù)據(jù)庫名和表名問題

    使用SQL查詢所有數(shù)據(jù)庫名和表名問題

    這篇文章主要介紹了使用SQL查詢所有數(shù)據(jù)庫名和表名問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11

最新評論