mysql -批量插入数据脚本

建表:


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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值