mysql - 使用 auto_increment 填充表的最有效方法

标签 mysql sql

我有一个只有 ID (INT auto_increment) 的表。 在给定参数之前用条目填充该表的最有效方法是什么?

这是我想出的一个存储过程,但是用 100000 条记录填充它需要相当多的时间:

DELIMITER $$
CREATE PROCEDURE insert_id(
IN createnum INT
)
BEGIN
  DECLARE i INT DEFAULT 1;

  WHILE i < createnum DO
    INSERT INTO table VALUES (i);
    SET i = i + 1;
  END WHILE;
END$$
DELIMITER ;

最佳答案

最快的方法是不使用任何循环,只使用纯 SQL

insert into table1 (id)
select a.N + b.N * 10 + c.N * 100 + d.N * 1000 + e.N * 10000 + 1 as N
from (select 0 as N union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) a
      , (select 0 as N union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) b
      , (select 0 as N union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) c
      , (select 0 as N union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) d
      , (select 0 as N union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) e
order by N

此查询插入 100000 行

这里是SQLFiddle 演示

<小时/>

如果需要,您可以将其包装在过程中

CREATE PROCEDURE insert_id(IN _maxid INT)
insert into table1(id)
select n
  from
(
  select a.N + b.N * 10 + c.N * 100 + d.N * 1000 + e.N * 10000 + f.N * 100000 + 1 N
    from (select 0 as N union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) a
      , (select 0 as N union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) b
      , (select 0 as N union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) c
      , (select 0 as N union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) d
      , (select 0 as N union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) e
      , (select 0 as N union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) f
) t
 where n <= _maxid;

此过程最多可以填充 100 万行。

使用示例:

CALL insert_id(5500);
CALL insert_id(100000);

您也可以看看这篇文章MySQL: Fill a table within a Stored Procedure efficiently

关于mysql - 使用 auto_increment 填充表的最有效方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19782130/

相关文章:

python - 这个脚本运行良好,直到他停止并显示错误

php - Mysql仅限制某一列的空行

php - mySQL 错误

sql - SQL Server 中主键和唯一聚集索引的性能差异

mysql - 如何在 CodeIgniter 中编写以下查询?

mysql - 在 MySQL 中使用 0..1 :1. .n 表进行 SQL 自动清理

php - 如何使用 mysql 查询显示排名

PHP和mysql的问题

mysql - SQL输出多个值

sql - MySQL 日期字段不包含任何值 - 导入时出现问题