php操作mysql迅速插入上百万数据

想要学习mysql存储,双机备份,主从架构的前提是必须要有大量的数据,大量数据插入数据表的速度很慢

超过百万级别的数据就需要几个小时。那么如何在几分钟内插入上百万数据呢?


原理:mysql插入数据库 插入时候并没有提交到mysql表里在insert后面需要执行commit操作才会插入数据库

默认mysql是自动提交,如果关闭自动提交,在insert几十万数据在进行commit那么会大大缩短入库时间

建表
用户表

CREATE TABLE `user` (

         `id` BIGINT (20),

         `name` VARCHAR(20)

    )ENGINE=INNODB;



日志表

CREATE TABLE `log` (

         `id` BIGINT (20),

         `msg` VARCHAR(20)

    )ENGINE=INNODB;

<?php
ini_set('max_execution_time', '0');//mysql执行时间 
@mysql_pconnect("localhost","root","ziguangruanjian") or die('connect failed'); 
@mysql_select_db("tiantian") or die('select db failed'); 
//这一步很重要  取消mysql的自动提交
mysql_query('SET AUTOCOMMIT=0;'); 

mysql_query('set names utf8'); 
$begin = time(); 
$count = 1;

for($i=1;$i<=1000000;$i++){ 
 mysql_query("insert into user values($i,'name')");
 //插入20W提交一次
 if($i%200000=='0'){
    $count++;
 mysql_query("insert into log values($i,$count)"); 
 mysql_query("commit"); 
 }
} 

$end = time(); 
echo "用时 ".($end-$begin)." 秒 <hr/>";



?>


测试结果只需要117秒

关联文章:使用mysql存储过程快速插入百万mysql测试数据


  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值