簡體   English   中英

MySQL自動增量列

[英]MySQL auto increment column

我看到一個奇怪的行為,其中我的自動增量列號僅以2而不是1的步長遞增。因此,我最終得到的行ID為1、3、5、7。我使用MySQL 5.6 + InnoDB作為引擎。 知道為什么會有這種怪異嗎?

mysql> select version();
+-----------------+
| version()       |
+-----------------+
| 5.6.20-68.0-log |
+-----------------+
1 row in set (0.00 sec)

mysql> show create table temp_table;
| superset_version | CREATE TABLE `temp_table` (
  `_id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'comm1',
  `name` varchar(100) NOT NULL COMMENT 'comm2',
  `start_time` bigint(20) NOT NULL COMMENT 'comm3',
  `updated_at` bigint(20) NOT NULL COMMENT 'comm4',
  `status` varchar(50) NOT NULL COMMENT 'comm5',
  PRIMARY KEY (`_id`)
) ENGINE=InnoDB AUTO_INCREMENT=27 DEFAULT CHARSET=utf8 |

請注意,insert將_id列增加了2。

mysql> insert into superset_version(name, start_time, updated_at, status) value("TEMP ROW", -1, -1, "erro");
    Query OK, 1 row affected, 1 warning (0.00 sec)

mysql> select * from superset_version order by _id desc limit 3;
+-----+----------+------------+------------+--------+
| _id | name     | start_time | updated_at | status |
+-----+----------+------------+------------+--------+
|  33 | TEMP ROW |         -1 |         -1 | erro   |
|  31 | TEMP ROW |         -1 |         -1 | erro   |
|  29 | TEMP ROW |         -1 |         -1 | erro   |
+-----+----------+------------+------------+--------+
3 rows in set (0.00 sec)

對於雙重檢查,您可以嘗試:

SELECT AUTO_INCREMENT
From `information_schema`.`TABLES`
WHERE   TABLE_NAME = '<<YOUR TABLE NAME HERE>>' AND
TABLE_SCHEMA = '<< YOUR DATABASE NAME HERE >>'

如果步長確實等於2,則可以替換它。

或另一種方式:檢查mysql.cnf / ini中的值:

auto-increment-increment
auto-increment-offset

auto_increment_increment設置很可能設置為2,因此mysql將自動遞增數增加2。使用show varibles like ...命令檢查設置。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM