Mysql批量数据脚本(十三)

函数:有返回值

public String getUserInfo(){

return user.toString();

}

存储过程:没有返回值

public void getUserInfo2(){

}

1建表:

#新建数据库
create database bigData;
use bigData;


#新建dept
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;


#新建emp
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;

2.设置参数log_bin_trust_function_creators


3.创建函数,保证每条数据不同

   3.1随机产生字符串

use bigData;
delimiter $$
CREATE FUNCTION rand_string(n INT) RETURN VARCHARS(255)
BEGIN
  DECLARE chars_str VARCHAR(100) DEFAULT 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
  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;
END $$

   3.2随机产生部门编号

delimiter $$
CREATE FUNCTION rand_num() RETURNS INT(5)
BEGIN
  DECLARE i INT DEFAULT 0;
  SET i=FLOOR(100+RAND()*10);
RETURN i;
END $$

4创建存储过程

  4.1往emp表中插入数据的存储过程

delimiter $$
CREATE PROCEDURE insert_emp(IN START INT(10),IN max_num INT(10))
BEGIN
DECLARE i INT DEFAULT 0;

#SET autocommit=0;把自动提交设置为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 $$

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

5调用存储过程

5.1dept表插入10条记录

delimiter;
CALL insert_dept(100,10);
select * from dept

5.2emp表插入30完条记录

CALL insert_emp(100001,300000);
select * from emp;


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值