列的自增屬性,一般用來設置整數(shù)列根據(jù)一定步長逐步增長的值,類似于其他數(shù)據(jù)庫的序列。不過這里的“序列”是基于特定一張表的。關于自增屬性的相關特性如下:

網(wǎng)站建設哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設計、網(wǎng)站建設、微信開發(fā)、小程序設計、集團企業(yè)網(wǎng)站建設等服務項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了上猶免費建站歡迎大家使用!
1. 控制自增屬性性能的變量:innodb_autoinc_lock_mode
innodb_autoinc_lock_mode=0
代表傳統(tǒng)模式,也就是說,在對有自增屬性的字段插入記錄時,會持續(xù)持有一個表級別的自增鎖,直到語句執(zhí)行結(jié)束為止。比如說下面兩條語句,SQL 1 在執(zhí)行期間,一直持有對表 f1 的表級自增鎖,接下來 SQL 2 執(zhí)行時鎖超時。
innodb_autoinc_lock_mode=1
代表連續(xù)模式,和傳統(tǒng)模式差不多,不同的點在于對于簡單的插入語句,比如 SQL 2,只在分配新的 ID 過程中持有一個輕量級的互斥鎖(線程級別,而不是事務級別),而不是直到語句結(jié)束才釋放的表鎖。
代表交錯模式。這個模式下放棄了自增表鎖,產(chǎn)生的值會不連續(xù)。不過這是性能最高的模式,多條插入語句可以并發(fā)執(zhí)行。MySQL 8.0 默認就是交錯模式。
那針對復制安全來說,以上三種模式,0 和 1 對語句級別安全,也就是產(chǎn)生的二進制日志復制到任何其他機器都數(shù)據(jù)都一致;2 對于語句級別不安全;三種模式對二進制日志格式為行的都安全。
2. 控制自增屬性的步長以及偏移量
一般用在主主復制架構或者多源復制架構里,主動規(guī)避主鍵沖突。
auto_increment_increment 控制步長
auto_increment_offset 控制偏移量
3. 對于要立刻獲取插入值的需求
就是說要獲取一張表任何時候的最大值,應該時刻執(zhí)行以下 SQL 3 ,而不是 SQL 2。SQL 2 里的函數(shù) last_insert_id() 只獲取上一條語句最開始的 ID,只適合簡單的 INSERT。
4. 自增列溢出現(xiàn)象
自增屬性的列如果到了此列數(shù)據(jù)類型的最大值,會發(fā)生值溢出。比如變更表 f1 的自增屬性列為 tinyint。
SQL 2 顯式插入最大值 127, SQL 3 就報錯了。所以這點上建議提前規(guī)劃好自增列的字段類型,提前了解上限值。
5. 自增列也可以顯式插入有符號的值
那針對這樣的,建議在請求到達數(shù)據(jù)庫前規(guī)避掉。
以插入語句的方法來解決此問題。
如下參考:
1.在添加字段之前,第一個zd應該首先檢查tb1表的當前結(jié)構。
2.將字段列instance添加到表中,如下圖。
3.再次查看表結(jié)構,比較添加字段之前和之后的情況。
4.最后,插入新的數(shù)據(jù)行,看看它是什么樣子,最后就加入了自動增長字段如下圖。
注意事項:
MySQL使用的SQL語言是訪問數(shù)據(jù)庫最常用的標準化語言。MySQL軟件采用雙重許可政策,分為社區(qū)版和商業(yè)版,由于其體積小,速度快,整體擁有成本低,尤其是開源這一特點,一般中小型網(wǎng)站開發(fā)都選擇MySQL作為網(wǎng)站數(shù)據(jù)庫。
1、增加字段前,首先查看tb1表當前的結(jié)構。
2、為表增加一列字段,實例。
3、再次查看表結(jié)構,對比字段增加前后。
4、最后,插入一行新的數(shù)據(jù)看一下效果。
注意事項:
MySQL所使用的 SQL 語言是用于訪問數(shù)據(jù)庫的最常用標準化語言。MySQL 軟件采用了雙授權政策,分為社區(qū)版和商業(yè)版,由于其體積小、速度快、總體擁有成本低,尤其是開放源碼這一特點,一般中小型網(wǎng)站的開發(fā)都選擇 MySQL 作為網(wǎng)站數(shù)據(jù)庫。
當前文章:mysql怎么插入自增型,mysql定義自增序列
本文鏈接:http://chinadenli.net/article15/dsihcgi.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、靜態(tài)網(wǎng)站、網(wǎng)站收錄、電子商務、網(wǎng)站維護、做網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)