mysql -批量插入数据脚本

被刻印的时光 ゝ 提交于 2020-02-21 03:25:57

建表:


create table dept(
id int unsigned primary key auto_increment,
deptno mediumint unsigned not null default 0,
dname varchar(20) not null default '',
loc varchar(13) NOT null default ''
) engine=innodb default charset=GBK;


create table emp (
id int unsigned primary key auto_increment,
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=innodb default charset=gbk;

要创建存储函数就要修改log_bin_trust_function_creators 

简单介绍一下,当二进制日志启用后,这个变量就会启用。它控制是否可以信任存储函数创建者,不会创建写入二进制日志引起不安全事件的存储函数。如果设置为0(默认值),用户不得创建或修改存储函数,除非它们具有除CREATE ROUTINE或ALTER ROUTINE特权之外的SUPER权限。 设置为0还强制使用DETERMINISTIC特性或READS SQL DATA或NO SQL特性声明函数的限制。 如果变量设置为1,MySQL不会对创建存储函数实施这些限制。 此变量也适用于触发器的创建。 请参见第23.7节“Binary Logging of Stored Programs

下面我们测试一下,当开启二进制日志后,如果变量log_bin_trust_function_creators为OFF,那么创建或修改存储函数就会报“ERROR 1418 (HY000): This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled (you *might* want to use the less safe log_bin_trust_function_creators variable) --->>详情

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 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPKRSTUVWXYZ' ;
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 $$ 

生成大于100的数:


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

员工:存储过程


 delimiter $$
 create procedure insert_emp(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 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$$

部门:存储过程


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$$

 

插入 员工:

 call insert_emp(100001,500000);  五十万个  时间: 155.885s

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!