当前位置:首页 > PHP教程 > php高级应用 > 列表

php在mysql里批量插入数据(代码实例)

发布:smiling 来源: PHP粉丝网  添加日期:2022-06-01 09:43:14 浏览: 评论:0 

假如说我有这样一个表,我想往这个表里面插入大量数据:

  1. CREATE TABLE IF NOT EXISTS `user_info` ( 
  2.  
  3. `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '自增主键'
  4.  
  5. `namevarchar(255) NOT NULL default '' COMMENT '姓名'
  6.  
  7. `age` int(11) NOT NULL default '0' COMMENT '年龄'
  8.  
  9. PRIMARY KEY (`id`) 
  10.  
  11. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户信息表'

批量插入

方法一、使用for循环插入

在往mysql插入少量数据的时候,我们一般用for循环

  1. $arr = [  
  2.  
  3.  
  4. 'name' => 'testname1'
  5.  
  6. 'age' => 18, 
  7.  
  8. ], 
  9.  
  10.  
  11. 'name' => 'testname2'
  12.  
  13. 'age' => 19, 
  14.  
  15. ], 
  16.  
  17.  
  18. 'name' => 'testname3'
  19.  
  20. 'age' => 18, 
  21.  
  22. ], 
  23.  
  24. ]; 
  25.  
  26.  
  27.  
  28. $servername = "localhost"
  29.  
  30. $port = 3306; 
  31.  
  32. $username = "username"
  33.  
  34. $password = "password"
  35.  
  36. $dbname = "mytestdb"
  37.  
  38.  
  39.  
  40. // 创建连接 
  41.  
  42. $conn = new mysqli($servername$username$password$dbname$port); 
  43.  
  44.  
  45.  
  46. // 检测连接 
  47.  
  48. if ($conn->connect_error) { 
  49.  
  50. die("connect failed: " . $conn->connect_error); 
  51.  
  52. }  
  53.  
  54.  
  55.  
  56. $costBegin = microtime(true); 
  57.  
  58.  
  59.  
  60. foreach($arr as $item) { 
  61.  
  62. $sql = sprintf("INSERT INTO user_info (name, age) VALUES ( '%s', %d);"$item['name'], (int)$item['age']);  
  63.  
  64. if ($conn->query($sql) === TRUE) { 
  65.  
  66. echo "insert success"
  67.  
  68. else { 
  69.  
  70. echo "Error: " . $sql . "<br>" . $conn->error; 
  71.  
  72.  
  73.  
  74.  
  75.  
  76. $costEnd = microtime(true); 
  77.  
  78. $cost = round($costEnd - $costBegin, 3); 
  79.  
  80. var_dump($cost); 
  81.  
  82.  
  83.  
  84. $conn->close(); 

假如说要批量插入大量数据,如果还用for循环的办法插入是没有问题的,只是时间会比较长。对比一下插入少量数据与插入大量数据,使用上面的for循环插入耗费的时间:条数时间(单位:秒)

php在mysql里批量插入数据(代码实例)

方法二、使用insert语句合并插入

mysql里面是可以使用insert语句进行合并插入的,比如

  1. INSERT INTO user_info (name, age) VALUES ('name1', 18), ('name2', 19);表示一次插入两条数据 
  2.  
  3.  
  4.  
  5. $arr = [  
  6.  
  7.  
  8. 'name' => 'testname1'
  9.  
  10. 'age' => 18, 
  11.  
  12. ], 
  13.  
  14.  
  15. 'name' => 'testname2'
  16.  
  17. 'age' => 19, 
  18.  
  19. ], 
  20.  
  21.  
  22. 'name' => 'testname3'
  23.  
  24. 'age' => 18, 
  25.  
  26. ], 
  27.  
  28. // 此处省略 
  29.  
  30. …… 
  31.  
  32. …… 
  33.  
  34. ]; 
  35.  
  36.  
  37.  
  38. $servername = "localhost"
  39.  
  40. $port = 3306; 
  41.  
  42. $username = "username"
  43.  
  44. $password = "password"
  45.  
  46. $dbname = "mytestdb"
  47.  
  48.  
  49.  
  50. // 创建连接 
  51.  
  52. $conn = new mysqli($servername$username$password$dbname$port); 
  53.  
  54.  
  55.  
  56. // 检测连接 
  57.  
  58. if ($conn->connect_error) { 
  59.  
  60. die("connect failed: " . $conn->connect_error); 
  61.  
  62. }  
  63.  
  64.  
  65.  
  66. $costBegin = microtime(true); 
  67.  
  68.  
  69.  
  70. if (!emptyempty($arr)) { 
  71.  
  72. $sql = sprintf("INSERT INTO user_info (name, age) VALUES "); 
  73.  
  74.  
  75.  
  76. foreach($arr as $item) { 
  77.  
  78. $itemStr = '( '
  79.  
  80. $itemStr .= sprintf("'%s', %d"$item['name'], (int)$item['age']); 
  81.  
  82. $itemStr .= '),'
  83.  
  84. $sql .= $itemStr
  85.  
  86.  
  87.  
  88.  
  89. // 去除最后一个逗号,并且加上结束分号 
  90.  
  91. $sql = rtrim($sql','); 
  92.  
  93. $sql .= ';'
  94.  
  95.  
  96.  
  97. if ($conn->query($sql) === TRUE) { 
  98.  
  99. else { 
  100.  
  101. echo "Error: " . $sql . "<br>" . $conn->error; 
  102.  
  103.  
  104.  
  105.  
  106.  
  107. $costEnd = microtime(true); 
  108.  
  109. $cost = round($costEnd - $costBegin, 3); 
  110.  
  111. var_dump($cost); 
  112.  
  113.  
  114.  
  115. $conn->close(); 

下面看一下少量数据与大量数据的时间对比。从总体时间上,可以看出insert合并插入比刚才for循环插入节约了很多时间,效果很明显条数时间(单位:秒)

php在mysql里批量插入数据(代码实例)

如果你觉得数组太大,想要减少sql错误的风险,也可以使用array_chunk将数组切成指定大小的块,然后对每个块进行insert合并插入.

Tags: php批量插入数据

分享到: