mysql大量数据插入存储过程
创建数据库
create database ceshi;
use ceshi;
创建表
create table ce(
id int not null auto_increment,
name varchar(50) default null,
pw char(50),
primary key(id));
存储过程
delimiter //
create procedure insert_ce(in item int)
begin
declare counter int;
declare i int;
set counter=item;
while counter >=1 do
insert into ce values(counter,concat('mysqls',counter),repeat('ab',5));
set counter =counter-1;
set i=i+1;
if i=1000 then
set i=0;
commit;
end if;
end while;
end
//
delimiter ;
十万条数据使用的时间是40分钟
另一钟方法:
create table t_2 (id serial,name char(5)) ;
delimiter $$
SET AUTOCOMMIT = 0$$
网趣购物系统静态版支持网站一键静态生成,采用动态进度条模式生成静态,生成过程更加清晰明确,商品管理上增加淘宝数据包导入功能,与淘宝数据同步更新!采用领先的AJAX+XML相融技术,速度更快更高效!系统进行了大量的实用性更新,如优化核心算法、增加商品图片批量上传、谷歌地图浏览插入等,静态版独特的生成算法技术使静态生成过程可随意掌控,从而可以大大减轻服务器的负担,结合多种强大的SEO优化方式于一体,使
create procedure test02(in i int)
begin
declare v_cnt decimal (10) default 0 ;
dd:loop
insert into t_2 values
(null,'aaaaa'),
(null,'aaaaa'),
(null,'aaaaa'),
(null,'aaaaa'),
(null,'aaaaa'),
(null,'aaaaa'),
(null,'aaaaa'),
(null,'aaaaa'),
(null,'aaaaa'),
(null,'aaaaa');
commit;
set v_cnt = v_cnt+10 ;
if v_cnt = i then leave dd;
end if;
end loop dd ;
end;$$
delimiter ;
十万条数据使用的时间是7分钟
设置缓存的话不到两种方法都是一份钟不到就好了,朋友说有可能是默认缓存过小的原因。可是,两种方法在同一个机子上测试,没有设置缓存,所用的时间就是差很多。
想问一下是什么原因造成的,还想知道插入多少条数据提交一次才是最优插入,第二种方法的注释?









