Navicat 工具 构造过程,实现百万数据添加

什么也不说了,直接上图
第一步,创建一个函数,创建函数过程,实现随机产生6位 字母,自己百度
这里写图片描述
第二步,创建一个过程,添加百万级的数据,其实原理很简单,就是改变数据库自动提交的方式,当自己把所有数据添加完后,一步提交
这里写图片描述
第三步,就是执行,我这里定义了参数,没有去掉,可以在参数的位置直接删除
运行结果这里写图片描述
到此400w数据添加完成!

另外,还有在cmd中运行的命令,大家可以试试,贴上代码

创建表DEPT

CREATE TABLE dept( /部门表/
deptno MEDIUMINT UNSIGNED NOT NULL DEFAULT 0,
dname VARCHAR(20) NOT NULL DEFAULT “”,
loc VARCHAR(13) NOT NULL DEFAULT “”
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ;

创建表EMP雇员

CREATE TABLE emp
(empno MEDIUMINT UNSIGNED NOT NULL DEFAULT 0, /编号/
ename VARCHAR(20) NOT NULL DEFAULT “”, /名字/
job VARCHAR(9) NOT NULL DEFAULT “”,/工作/
mgr MEDIUMINT UNSIGNED NOT NULL DEFAULT 0,/上级编号/
hiredate DATE NOT NULL,/入职时间/
sal DECIMAL(7,2) NOT NULL,/薪水/
comm DECIMAL(7,2) NOT NULL,/红利/
deptno MEDIUMINT UNSIGNED NOT NULL DEFAULT 0 /部门编号/
)ENGINE=MyISAM DEFAULT CHARSET=utf8 ;

工资级别表

CREATE TABLE salgrade
(
grade MEDIUMINT UNSIGNED NOT NULL DEFAULT 0,
losal DECIMAL(17,2) NOT NULL,
hisal DECIMAL(17,2) NOT NULL
)ENGINE=MyISAM DEFAULT CHARSET=utf8;

INSERT INTO salgrade VALUES (1,700,1200);
INSERT INTO salgrade VALUES (2,1201,1400);
INSERT INTO salgrade VALUES (3,1401,2000);
INSERT INTO salgrade VALUES (4,2001,3000);
INSERT INTO salgrade VALUES (5,3001,9999);

随机产生字符串

定义一个新的命令结束符合

delimiter $$

删除自定的函数

drop function rand_string $$

这里我创建了一个函数.

rand_string(n INT) rand_string 是函数名 (n INT) //该函数接收一个整数

create function rand_string(n INT)
returns varchar(255) #该函数会返回一个字符串
begin

chars_str定义一个变量 chars_str,类型是 varchar(100),默认值’abcdefghijklmnopqrstuvwxyzABCDEFJHIJKLMNOPQRSTUVWXYZ’;

declare chars_str varchar(100) default
‘abcdefghijklmnopqrstuvwxyzABCDEFJHIJKLMNOPQRSTUVWXYZ’;
declare return_str varchar(255) default ”;
declare i int default 0;
while i < n do
set return_str =concat(return_str,substring(chars_str,floor(1+rand()*52),1));
set i = i + 1;
end while;
return return_str;
end $$

delimiter ;
select rand_string(6);

随机产生部门编号

delimiter

dropfunctionrandnum

这里我们又自定了一个函数

create function rand_num( )
returns int(5)
begin
declare i int default 0;
set i = floor(10+rand()*500);
return i;
end $$

delimiter ;
select rand_num();

********************************

向emp表中插入记录(海量的数据)

delimiter

dropprocedureinsertemp

随即添加雇员[光标] 400w

create procedure insert_emp(in start int(10),in max_num int(10))
begin
declare i int default 0;

set autocommit =0 把autocommit设置成0

set autocommit = 0;
repeat
set i = i + 1;
insert into emp values ((start+i) ,rand_string(6),’SALESMAN’,0001,curdate(),2000,400,rand_num());
until i = max_num
end repeat;
commit;
end $$

delimiter ;

调用刚刚写好的函数, 1800000条记录,从100001号开始

call insert_emp(100001,4000000);

****************************************************

向dept表中插入记录

delimiter

dropprocedureinsertdept

create procedure insert_dept(in start int(10),in max_num int(10))
begin
declare i int default 0;
set autocommit = 0;
repeat
set i = i + 1;
insert into dept values ((start+i) ,rand_string(10),rand_string(8));
until i = max_num
end repeat;
commit;
end $$

delimiter ;
call insert_dept(100,10);

————————————————

向salgrade 表插入数据

delimiter

dropprocedureinsertsalgrade

create procedure insert_salgrade(in start int(10),in max_num int(10))
begin
declare i int default 0;
set autocommit = 0;
ALTER TABLE emp DISABLE KEYS;
repeat
set i = i + 1;
insert into salgrade values ((start+i) ,(start+i),(start+i));
until i = max_num
end repeat;
commit;
end $$
delimiter ;

测试不需要了

call insert_salgrade(10000,1000000);

———————————————-

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值