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

MySQL中使用auto_increment修改初始值和步長

 更新時間:2024年05月22日 10:30:28   作者:Clearlove7·11  
本文主要介紹了MySQL中使用auto_increment修改初始值和步長,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

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)限問題

    這篇文章主要介紹了Navicat配置mysql數(shù)據(jù)庫用戶權(quán)限問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • MySQL中的CONCAT函數(shù)使用教程

    MySQL中的CONCAT函數(shù)使用教程

    這篇文章主要介紹了MySQL中的CONCAT函數(shù)使用教程,是Python入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-05-05
  • Mysql寫入數(shù)據(jù)十幾秒后被自動刪除了如何解決

    Mysql寫入數(shù)據(jù)十幾秒后被自動刪除了如何解決

    這篇文章主要介紹了Mysql寫入數(shù)據(jù)十幾秒后被自動刪除了如何解決,文章通過圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • MySQL查詢指定字段不是數(shù)字與逗號的sql

    MySQL查詢指定字段不是數(shù)字與逗號的sql

    今天小編遇到一個問題因?yàn)榫庉嫷牟患?xì)心不小心將關(guān)鍵詞寫到相關(guān)文章里面導(dǎo)致頁面無法生成,這里用sql語言將這些內(nèi)容獲取出來
    2020-02-02
  • mysql主從復(fù)制的實(shí)現(xiàn)步驟

    mysql主從復(fù)制的實(shí)現(xiàn)步驟

    本文主要介紹了mysql主從復(fù)制的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • mysql并發(fā)控制原理知識點(diǎn)

    mysql并發(fā)控制原理知識點(diǎn)

    在本篇文章里小編給大家整理的是一篇關(guān)于mysql并發(fā)控制原理知識點(diǎn)內(nèi)容,需要的朋友們參考下吧。
    2020-02-02
  • MySQL刪除了記錄不生效的原因排查

    MySQL刪除了記錄不生效的原因排查

    這篇文章主要介紹了MySQL刪除了記錄不生效的原因排查,幫助大家解決MySQL刪除語句不生效的問題,感興趣的朋友可以了解下
    2020-11-11
  • MySQL如何生成唯一的server-id

    MySQL如何生成唯一的server-id

    這篇文章主要給大家介紹了關(guān)于MySQL如何生成唯一的server-id的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • MySQL分組查詢獲取每組最新的一條數(shù)據(jù)詳解(group?by)

    MySQL分組查詢獲取每組最新的一條數(shù)據(jù)詳解(group?by)

    在寫報表功能時遇到一個需要根據(jù)用戶id分組查詢最新一條錢包明細(xì)數(shù)據(jù)的需求,下面這篇文章主要給大家介紹了關(guān)于MySQL分組查詢獲取每組最新的一條數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下
    2024-08-08
  • mysql查看死鎖與去除死鎖示例詳解

    mysql查看死鎖與去除死鎖示例詳解

    這篇文章主要給大家介紹了關(guān)于mysql查看死鎖與去除死鎖的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12

最新評論