MySQL的优化--------慢查询(2)____用存储过程创建400万数量及的表

本文是转载于:https://blog.csdn.net/gcxzflgl/article/details/78930489,感谢作者君

第一步:创建部门表(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( /*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

第三步:创建薪资级别表(salgrade)

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;

第四步:将工资添加为5个等级

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);

第五步:将命令字符中的以分号结尾替换为$$结尾,因为在命令窗口的存储过程中有                许多分号结尾的,不改会冲突

注:我这里说的是用Mysql命令窗口,如果用的是Navicat for Mysql就不用替换了

#随机产生字符串
#定义一个新的命令结束符
delimiter $$
#删除自动以函数
drop function rand_string $$

第六步:创建函数

#rand_string(n INT) rand_string 是函数名(n INT)  //该函数传参一个整数
create function rand_string(n INT)
returns varchar(255) 
begin
declare chars_str varchar(100) default 
 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
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 $$

再创建一个函数

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

第七步:创建存储过程

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 ;

第九步:调用刚刚写好的函数,从100001号开始,产生4000000记录

call insert_emp(100001,4000000);

 

第十步:向dept表中插入数据


delimiter $$  
drop procedure insert_dept $$ 
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); 

这样就完成了。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值