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

相关阅读:

  • A股市场具有较强估值支撑 机构看好政策受益板块 2019-04-12
  • 传奇“斗士”谢幕:只可远观李敖,不然会被他亵玩 2019-04-12
  • 社会民生--北京频道--人民网 2019-04-03
  • 荷兰音乐节巴士冲撞人群事件致1死3伤 肇事者自首 2019-03-25
  • 岳麓书院再现兴盛之貌 2019-03-24
  • 女性之声——全国妇联 2019-03-23
  • 多彩课堂熔铸红色魂——甘祖昌干部学院教学素描 2019-03-23
  • 以谁之名做事,自然就该谁负责。法庭的判决确实没有道理。共产党的形象来自于每个共产党员的表现,如果事情做得有问题,把责任往哪个人身上一推就可以事不关己高高挂起的话 2019-03-20
  • 全国政协常委、中国石油大学(北京)校长张来斌谈“贯彻五大发展理念 推进高校改革发展” 2019-03-20
  • 浙大科研团队15载攻克歼20等飞机装配系列难题 2019-03-18
  • 人民网时尚携20位明星大咖齐拜年  2019-03-18
  • 统计局:5月份经济运行主要指标呈现五大特点 2019-03-15
  • 进不了朋友圈,身份认同难。 2019-03-15
  • 朗斯卫浴向伟昌:舒服才是完美卫浴空间的必备要素 2019-03-15
  • 人为某种意识而奋斗是幸福的,获得成绩或成就更幸福。 2019-03-11
  • 981| 814| 529| 776| 761| 241| 993| 272| 930| 12| 928| 690| 424| 927| 334|