日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL主键自增长报duplicate_MySQL使用on duplicate key update引起主键不连续自增

發布時間:2025/3/11 数据库 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL主键自增长报duplicate_MySQL使用on duplicate key update引起主键不连续自增 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

innodb_autoinc_lock_mode中有3種模式,0,1,2,數據庫默認是1的情況下,每次使用insert into … on duplicate key update 的時候都會把簡單自增id增加,不管是發生了insert還是update

innodb_autoinc_lock_mode參數詳解

tradition(innodb_autoinc_lock_mode=0) 模式:

1、它提供了一個向后兼容的能力

2、在這一模式下,所有的insert語句(“insert like”) 都要在語句開始的時候得到一個表級的auto_inc鎖,在語句結束的時候才釋放這把鎖,注意呀,這里說的是語句級而不是事務級的,一個事務可能包涵有一個或多個語句。

3、它能保證值分配的可預見性,與連續性,可重復性,這個也就保證了insert語句在復制到slave的時候還能生成和master那邊一樣的值(它保證了基于語句復制的安全)。

4、由于在這種模式下auto_inc鎖一直要保持到語句的結束,所以這個就影響到了并發的插入。

consecutive(innodb_autoinc_lock_mode=1) 模式:

1、這一模式下去simple insert 做了優化,由于simple insert一次性插入值的個數可以立馬得到確定,所以mysql可以一次生成幾個連續的值,用于這個insert語句;總的來說這個對復制也是安全的(它保證了基于語句復制的安全)

2、這一模式也是mysql的默認模式,這個模式的好處是auto_inc鎖不要一直保持到語句的結束,只要語句得到了相應的值后就可以提前釋放鎖

interleaved(innodb_autoinc_lock_mode=2) 模式:

1、由于這個模式下已經沒有了auto_inc鎖,所以這個模式下的性能是最好的;但是它也有一個問題,就是對于同一個語句來說它所得到的auto_incremant值可能不是連續的。

總結

以上是生活随笔為你收集整理的MySQL主键自增长报duplicate_MySQL使用on duplicate key update引起主键不连续自增的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。