登录
首页 >  数据库 >  MySQL

Mysql使用存储过程快速添加百万数据的示例代码

来源:脚本之家

时间:2023-01-07 12:02:05 231浏览 收藏

来到golang学习网的大家,相信都是编程学习爱好者,希望在这里学习数据库相关编程知识。下面本篇文章就来带大家聊聊《Mysql使用存储过程快速添加百万数据的示例代码》,介绍一下MySQL数据、存储过程,希望对大家的知识积累有所帮助,助力实战开发!

CREATE TABLE `t_sales` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(32) COLLATE utf8_bin DEFAULT NULL COMMENT '用户名',
  `password` varchar(64) COLLATE utf8_bin DEFAULT NULL COMMENT '密码 MD5存储',
  `register_time` timestamp NULL DEFAULT NULL COMMENT '注册时间',
  `type` int(1) DEFAULT NULL COMMENT '用户类型 1,2,3,4 随机',
  PRIMARY KEY (`id`),
  KEY `idx_username` (`username`) USING BTREE
)

然后创建存储过程,批量添加数据。

  • 用户名以常量和数字拼接
  • 密码是MD5密码
  • 注册时间是当前时间随机往前推几天
  • type是取1-4随机范围值
create procedure salesAdd()
begin 
 declare i int default 11;
   while i 

<p>然后调用存储过程</p>

<pre class="brush:sql;">
call salesAdd()

改进版

虽然使用存储过程添加数据相对一个个添加更加便捷,快速,但是添加几百万数据要花几个小时时间也是很久的,后面在网上找到不少资料,发现mysql每次执行一条语句都默认自动提交,这个操作非常耗时,所以在在添加去掉自动提交。设置 SET AUTOCOMMIT = 0;

create procedure salesAdd()
begin 
 declare i int default 1;
 set autocommit = 0;   
   while i 

<p>执行时间387秒,约为六分钟,其中还有一半时间用于md5、随机数的计算。</p>
<blockquote>
<p>[SQL]<br>
call salesAdd();<br>
受影响的行: 0<br>
时间: 387.691s</p>
</blockquote>
<p>好了,本文到此结束,带大家了解了《Mysql使用存储过程快速添加百万数据的示例代码》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多数据库知识!</p>
声明:本文转载于:脚本之家 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表