时间:2021-07-01 10:21:17 帮助过:6人阅读
执行以下命令查看mysql版本是否开启了函数功能
show variables like ‘log_bin_trust_function_creators‘; set global log_bin_trust_function_creators=1;
执行后再看是否生效
创建函数(作用:生产随机字符串)
delimiter $$ create function rand_string(n int) returns varchar(255) begin declare chars_str varchar(100) default ‘qwertyuiopasdfghjklzxcvbnm‘; 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 $$ create function rand_num() returns int(5) begin declare i int default 0; set i=floor(100+rand()*10); return i; end $$
创建完后我们可以查看创建的函数:
接着我们来创建存储过程:
1:创建往emp表中插入数据的存储过程
delimiter $$ create procedure insert_emp(in start int(10),in max_num int(10)) begin declare i int default 0; /*把autocommit设置成0*/ set autocommit= 0; repeat set i=i+1; insert into emp(empno,ename,job,mgr,hiredate,sal,comm,deptno) values((start+i),rand_string(6),‘SALESMAN‘,0001,curdate(),2000,400,rand_num()); until i=max_num end repeat; commit; end $$
2:创建往dept表中插入数据的存储过程
delimiter $$ 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(deptno,dname,loc) values((start+i),rand_string(10),rand_string(8)); until i=max_num end repeat; commit; end $$
可以查看已经创建的procedure:
上面2个show create procedure请分开执行,我这里直截图就只显示一个procedure啦
那我们可以开始调用存储过程了
call insert_dept(1,100);//从deptno为1起插入100条随机生成数据
执行后我的部分数据如下:
call insert_emp(1001,50000);//从empno为1001起插入50000条随机生成数据
执行后部分截图如下:
至此,整个批量插入完成...关于存储过程和函数,手册上有更详细的介绍啦,我这里就不再赘述了吧....
mysql使用存储过程&函数实现批量插入
标签:log variable primary toc rust charset 字符串 iter star