MYSQL - 如何避免主 ID 浪费?

标签 mysql load auto-increment

如何在通过多个加载语句插入记录时避免跳过主 ID?

我通过 LOAD 语句将包含 150 条记录的文件插入到表中。

插入后表中最后一个primary id为150。

现在,当我通过加载语句插入另一个包含 100 条记录的文件时,分配给第一条记录的主 ID 是 251,而不是 151。

如何避免这些主 ID 浪费?

更多信息: 例如:

mysql> desc test_data;
+------------+------------------+------+-----+---------+----------------+
| Field      | Type             | Null | Key | Default | Extra          |
+------------+------------------+------+-----+---------+----------------+
| id         | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| name       | varchar(255)     | NO   | UNI | NULL    |                |
| image      | varchar(255)     | NO   |     | NULL    |                |
| created_at | datetime         | NO   |     | NULL    |                |
+------------+------------------+------+-----+---------+----------------+
4 rows in set (0.00 sec)

我的加载语句 -

 LOAD DATA LOCAL INFILE '~/test_2.dat' 
       INTO TABLE test_data 
       FIELDS TERMINATED BY '|' 
       LINES TERMINATED BY '\n' 
       set created_at=CURRENT_TIMESTAMP;

文件 test_2.dat 中的示例数据:

|Peter|peter.jpg
|sam|sam.jpg
|radnor|radnor.jpg
|bruce|bruce.jpg

这是加载该文件后的表结构。

mysql> show create table test_data;

| test_data | CREATE TABLE `test_data` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(255) NOT NULL,
  `image` varchar(255) NOT NULL,
  `created_at` datetime NOT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `name` (`name`)
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=latin1 |

现在,此表中的 max(id) 为 4。但为什么 AUTO_INCREMENT 值现在设置为“8”?不应该设置为“5”吗?

最佳答案

您可以在主 ID 上将 AUTO_INCREMENT 标记为 true 以在加载期间跳过它们。 更多信息有助于更好地回答。

关于MYSQL - 如何避免主 ID 浪费?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10982509/

相关文章:

plugins - solr5 中的 EdgeNGramFilterFactory 更改

mysql - 为什么添加 INNER JOIN 会使此查询变得如此缓慢?

mysql - 在Mysql中将一个存储过程结果作为参数传递给另一个存储过程

php - 在外部 php 文件 Joomla 中包含 Jfactory 类

jquery - fullcalendar mysql 选择 WHERE 当前日期范围

javascript - 如何在浏览页面时保持音频播放?

java - 使用 pdfbox 在现有表单 pdf 上写入

MYSQL - 使用 SuperType/Subtype 和自动增量插入

mysql - 如何更新现有记录以在 MySQL 中具有新的 auto_increment id?

mysql - MySQL、InnoDB自增索引的结构