当前位置:山东群英会技巧>文章>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条随机生成数据

相关阅读:

  • 学习贯彻十九大精神不忘初心 牢记使命 奔向未来 2018-11-29
  • 读出你的爱!市儿童公园父亲节亲子朗诵会等你来 2018-11-13
  • 默滕斯神仙球卢卡库2球 比利时3 2018-11-13
  • 世界杯专版 竞猜型彩票 赔率是公认的竞猜利器 2018-11-10
  • 候选案例:亿滋希望厨房 2018-11-10
  • 世界杯五大未解之谜,第五个你最关心,但一样没答案 2018-11-08
  • 端午假期陕西接待游客1913.2万人次 旅游收入86.15亿元 2018-11-02
  • 努力把各级党组织锻造得更加坚强有力——四论认真学习贯彻省委十二届四次全会精神 2018-11-02
  • 端午节,广州荔枝湾“扒龙船” 2018-11-02
  • 回复@“老笑头”,本人觉得你越来越幼稚可笑了。连“再什么主义,你没生产资料咋劳动?”这样的话都说出来了。你长大后没有经历过全中国的公有制时代,不清楚是可能... 2018-10-29
  • 国务院安委办约谈三市政府负责人 2018-10-23
  • 湖南着力推动习近平新时代中国特色社会主义思想深入人心 2018-10-22
  • 冠军教头离任!四川队官宣不再与杨学增指导续约 2018-09-25
  • 【理上网来·辉煌十九大】十九大报告指明实现干部清正、政府清廉、政治清明改革途径 2018-09-16
  • 一语惊坛(5月10日):半岛和平,是中朝两国的共同愿望。 2018-09-14
  • 888| 292| 625| 826| 299| 474| 530| 794| 223| 767| 266| 914| 772| 22| 287|