当前位置:山东群英会技巧>文章>MySQL

mysql批量数据脚本

mysql批量数据脚本

  • 山东群英会技巧 www.iba5.com.cn 1 建表

    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;
  • 2 设置参数

    show variables like 'log_bin_trust_function_creators';set global log_bin_trust_function_creators=1;
  • 3 创建函数

     a.随机产生字符串
     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 $$
     b.随机产生部门编号
     delimiter $$
     create function rand_num() returns int(5)
     begin
       declare i int default 0;
       set i=floor(100+rand()*10); return i; end $$
  • 4 创建存储过程

    a.创建往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 $$
    b.创建往dept表中插入数据的存储过程
    delimiter $$create procedure insert_dept(in start int(10),in max_num int(10))begindeclare 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 调用存储过程

    call insert_dept(100,10);//从deptno为100起插入10条随机生成数据call insert_emp(100001,5000000);//从empno为100001起插入5000000条随机生成数据

相关阅读:

  • 特不靠谱先生言而无信,翻云覆雨小人,王八吃秤砣铁了心要与我朝为敌了。[福尔摩斯] 2019-02-12
  • C罗一人扛起葡萄牙前进 前三届世界杯共打进三球 2019-02-05
  • 习近平在上海合作组织青岛峰会欢迎宴会上的祝酒辞(全文) 2019-02-05
  • 民警扶摔倒大妈反被讹,监控证明清白后遭怼:看见警车吓的! 2019-02-04
  • 法国偶遇赵薇纤细瘦身成功 舒淇背粉包少女心十足 2019-01-23
  • 只有两种可能,你任选一种 2019-01-20
  • 【专题】节能降耗 保卫蓝天——浙江省暨杭州市2018年节能宣传周 2019-01-18
  • 违法和不良信息举报受理和处置管理办法 2019-01-12
  • 国务院关税税则委员会对原产于美国进口商品加征关税公告 2019-01-12
  • 互联网论坛社区服务管理规定 2019-01-02
  • 学习贯彻十九大精神不忘初心 牢记使命 奔向未来 2018-11-29
  • 读出你的爱!市儿童公园父亲节亲子朗诵会等你来 2018-11-13
  • 默滕斯神仙球卢卡库2球 比利时3 2018-11-13
  • 世界杯专版 竞猜型彩票 赔率是公认的竞猜利器 2018-11-10
  • 候选案例:亿滋希望厨房 2018-11-10
  • 796| 486| 616| 564| 400| 921| 596| 497| 972| 764| 540| 208| 819| 193| 156|