2

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

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

插入后表中的最后一个主 id 是 150。

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

我如何避免这些主要的身份浪费?

更多信息:例如:

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”吗?

4

1 回答 1

0

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

于 2012-06-11T14:56:12.790 回答