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

MySQL自增主鍵ID設置為0有坑

 更新時間:2025年06月18日 09:38:30   作者:Muscleheng  
本文主要介紹了MySQL自增主鍵插入ID=0會被自動替換為下一個自增值,導致數(shù)據(jù)關聯(lián)異常,原因在于系統(tǒng)將0視為未指定值,可通過修改SQL模式解決,感興趣的可以了解一下

場景:A、B兩個數(shù)據(jù)庫有同樣的一個T表,從A庫T表導出數(shù)據(jù)、導入到B庫T表,導入成功后發(fā)現(xiàn)T表中有一條數(shù)據(jù)和其他表數(shù)據(jù)關聯(lián)不上了,通過排查才發(fā)現(xiàn),T表中的id為自增主鍵,有一條數(shù)據(jù)的id為0,導入到B庫的T表后id不再是0,而是下一個自增值,所以其他表如果是如果該id來和T表關聯(lián),那自然是關聯(lián)不上。

 PS:同一個表里面導出數(shù)據(jù)后再重新導入也會出現(xiàn)同樣的問題。

一、實踐一下

創(chuàng)建表:

CREATE TABLE `dept` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(32) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

添加數(shù)據(jù),把其中一條數(shù)據(jù)id修改為0

導出數(shù)據(jù)后清除數(shù)據(jù)再執(zhí)行SQL導入:

INSERT INTO `dept` (`id`, `name`) VALUES (0, '數(shù)據(jù)1');
INSERT INTO `dept` (`id`, `name`) VALUES (2, '數(shù)據(jù)2');

導入后的數(shù)據(jù)情況:

可以看到,導出后重新導入,id為0的數(shù)據(jù)變成3了,變成了下一個自增值。

二、原因

在 MySQL 中,當表有一個自增主鍵列(AUTO_INCREMENT)時,如果你嘗試插入 ID=0 的記錄,實際插入的 ID 不會保持為 0,而是會使用下一個自增值。
因為默認情況下,MySQL 將 ID=0 的插入請求視為"未指定值",因此會使用自增序列中的下一個可用值。
這種行為可以通過 SQL 模式控制:如果啟用了 NO_AUTO_VALUE_ON_ZERO SQL 模式,MySQL 會允許插入 ID=0,默認情況下這個模式是禁用的。

三、解決方案

1. 手動修改數(shù)據(jù)

不正規(guī)。 

2. 臨時修改 SQL 模式:

SET SESSION sql_mode='NO_AUTO_VALUE_ON_ZERO';
INSERT INTO your_table (id, ...) VALUES (0, ...);

3. 永久修改 SQL 模式(在 my.cnf/my.ini 中)

不推薦:

sql_mode=NO_AUTO_VALUE_ON_ZERO,...其他模式...

注意:不建議在自增主鍵中插入0值,這可能會導致某些奇奇怪怪的問題。

到此這篇關于MySQL自增主鍵ID設置為0有坑的文章就介紹到這了,更多相關MySQL自增主鍵ID設置為0內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 對比分析MySQL語句中的IN 和Exists

    對比分析MySQL語句中的IN 和Exists

    mysql中in 是把外表和內表作hash 連接,而exists是對外表作loop循環(huán),每次loop循環(huán)再對內表進行查詢。一直以來認為exists比in效率高的說法是不準確的。
    2018-06-06
  • mysql的存儲過程、游標 、事務實例詳解

    mysql的存儲過程、游標 、事務實例詳解

    這篇文章主要介紹了mysql的存儲過程、游標 、事務實例詳解的相關資料,這里舉實例說明MySQL 存儲過程與游標和事務,需要的朋友可以參考下
    2017-08-08
  • 簡單介紹MySQL中索引的使用方法

    簡單介紹MySQL中索引的使用方法

    這篇文章主要介紹了簡單介紹MySQL中索引的使用方法,是MySQL入門學習中的基礎知識,需要的朋友可以參考下
    2015-05-05
  • MySQL 橫向衍生表(Lateral Derived Tables)的實現(xiàn)

    MySQL 橫向衍生表(Lateral Derived Tables)的實現(xiàn)

    橫向衍生表適用于在需要通過子查詢獲取中間結果集的場景,相對于普通衍生表,橫向衍生表可以引用在其之前出現(xiàn)過的表名,本文就來介紹一下MySQL 橫向衍生表(Lateral Derived Tables)的實現(xiàn),感興趣的可以了解一下
    2025-06-06
  • Mysql中的表分區(qū)使用解讀

    Mysql中的表分區(qū)使用解讀

    這篇文章主要介紹了Mysql中的表分區(qū)使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2025-05-05
  • MySQL自定義函數(shù)簡單用法示例

    MySQL自定義函數(shù)簡單用法示例

    這篇文章主要介紹了MySQL自定義函數(shù)簡單用法,結合實例形式分析了mysql自定義函數(shù)的基本定義、使用方法及操作注意事項,需要的朋友可以參考下
    2018-12-12
  • MySQL之存儲引擎使用及說明

    MySQL之存儲引擎使用及說明

    這篇文章主要介紹了MySQL之存儲引擎使用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • mysql常用函數(shù)與視圖索引全面梳理

    mysql常用函數(shù)與視圖索引全面梳理

    這篇文章主要介紹了mysql的常用函數(shù)與視圖索引的特點與作用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-10-10
  • mysql中的判斷函數(shù)和分支語句詳解

    mysql中的判斷函數(shù)和分支語句詳解

    本文介紹了SQL中常用的判斷函數(shù)和分支語句,判斷函數(shù)包括if()、ifnull()以及nullif(),用于處理數(shù)據(jù)判斷和空值處理,分支語句分為多條件判斷和固定值判斷,便于根據(jù)不同條件執(zhí)行相應邏輯,這些功能在數(shù)據(jù)處理和查詢中非常實用
    2024-10-10
  • mysql優(yōu)化利器之explain使用介紹

    mysql優(yōu)化利器之explain使用介紹

    這篇文章主要介紹了mysql優(yōu)化利器之explain使用介紹,需要的朋友可以參考下
    2017-01-01

最新評論