博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL批量数据脚本示例
阅读量:7261 次
发布时间:2019-06-29

本文共 3384 字,大约阅读时间需要 11 分钟。

一、建表

# 新建库create database bigData;use bigData;  #1 建表deptCREATE 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=UTF8 ;    #2 建表empCREATE 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=UTF8 ;

二、设置参数log_bin_trust_function_creators

  当开启二进制日志后,如果变量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)这样的错误。因为二进制日志的一个重要功能是用于主从复制,而存储函数有可能导致主从的数据不一致。所以当开启二进制日志后,参数log_bin_trust_function_creators就会生效,限制存储函数的创建、修改、调用。

 

show variables like 'log_bin_trust_function_creators';

set global log_bin_trust_function_creators=1;
# 这样添加了参数以后,如果mysqld重启,上述参数又会消失,永久方法:
windows下my.ini[mysqld]加上log_bin_trust_function_creators=1
linux下 /etc/my.cnf下my.cnf[mysqld]加上log_bin_trust_function_creators=1

三、创建函数,保证每条数据都不同

随机产生字符串

DELIMITER $$CREATE FUNCTION rand_string(n INT) RETURNS VARCHAR(255)BEGIN    ##方法开始 DECLARE chars_str VARCHAR(100) DEFAULT   'abcdefghijklmnopqrstuvwxyzABCDEFJHIJKLMNOPQRSTUVWXYZ';  ##声明一个 字符窜长度为 100 的变量 chars_str ,默认值  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));##concat 连接函数  ,substring(a,index,length) 从index处开始截取 SET i = i + 1; END WHILE; RETURN return_str;END $$ #假如要删除#drop function rand_string;

随机产生部门编号

#用于随机产生部门编号DELIMITER $$CREATE FUNCTION rand_num( ) RETURNS INT(5)  BEGIN    DECLARE i INT DEFAULT 0;   SET i = FLOOR(100+RAND()*10);  RETURN i;   END $$  #假如要删除#drop function rand_num;

四、创建存储过程

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

DELIMITER $$CREATE PROCEDURE insert_emp10000(IN START INT(10),IN max_num INT(10))  BEGIN  DECLARE i INT DEFAULT 0;   #set autocommit =0 把autocommit设置成0  ;提高执行效率 SET autocommit = 0;     REPEAT  ##重复 SET i = i + 1;   INSERT INTO emp10000 (empno, ename ,job ,mgr ,hiredate ,sal ,comm ,deptno ) VALUES ((START+i) ,rand_string(6),'SALESMAN',0001,CURDATE(),FLOOR(1+RAND()*20000),FLOOR(1+RAND()*1000),rand_num());   UNTIL i = max_num   ##直到  上面也是一个循环 END REPEAT;  ##满足条件后结束循环 COMMIT;   ##执行完成后一起提交 END $$ #删除# DELIMITER ;# drop PROCEDURE insert_emp;

创建往dept表中插入数据的存储过程

#执行存储过程,往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 $$  #删除# DELIMITER ;# drop PROCEDURE insert_dept;

五、调用存储过程

DELIMITER ;CALL insert_dept(100,10); #执行存储过程,往emp表添加50万条数据DELIMITER ;    #将 结束标志换回 ;CALL insert_emp(100001,500000); CALL insert_emp10000(100001,10000);

 

转载于:https://www.cnblogs.com/runtimeexception/p/10374522.html

你可能感兴趣的文章
Flutter TextField详解 | 掘金技术征文
查看>>
jvm优化—— 图解垃圾回收
查看>>
React Native项目自动化打包发布
查看>>
iOS 部署智能合约
查看>>
kafka生产者Producer参数设置及参数调优建议-kafka 商业环境实战
查看>>
2018.06.27 Day01 牛客网java刷题
查看>>
Python正则表达式初识(九)
查看>>
说说 Vue.js 中的 v-cloak 指令
查看>>
Python微信公众号开发
查看>>
react-native 开发前的见面礼 -- 误入依赖坑
查看>>
手把手带你实现一个符合promiseA+规范的promise类库
查看>>
Rx中的那些操作符
查看>>
Kotlin的基本语法和类型
查看>>
聊聊iOS中的多继承和多重代理
查看>>
1.Ajax基础知识及核心原理
查看>>
Okhttp源码阅读(二)——一个缓存是怎么触发的
查看>>
Vuecli3开发环境搭建
查看>>
Go语言学习(1) - 简介
查看>>
【刘文彬】EOS商业落地利器:多签名操作与应用
查看>>
Nginx转发TCP实现负载均衡
查看>>