文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

mysql中怎么使用php批量插入数据

2024-04-02 19:55

关注

这篇文章将为大家详细讲解有关mysql中怎么使用php批量插入数据,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

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

  CREATE TABLE IF NOT EXISTS `user_info` (

  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '自增主键',

  `name` varchar(255) NOT NULL default '' COMMENT '姓名',

  `age` int(11) NOT NULL default '0' COMMENT '年龄',

  PRIMARY KEY (`id`)

  ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户信息表';

  批量插入

  方法一、使用for循环插入

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

  $arr = [

  [

  'name' => 'testname1',

  'age' => 18,

  ],

  [

  'name' => 'testname2',

  'age' => 19,

  ],

  [

  'name' => 'testname3',

  'age' => 18,

  ],

  ];

  $servername = "localhost";

  $port = 3306;

  $username = "username";

  $password = "password";

  $dbname = "mytestdb";

  // 创建连接

  $conn = new mysqli($servername, $username, $password, $dbname, $port);

  // 检测连接

  if ($conn->connect_error) {

  die("connect failed: " . $conn->connect_error);

  }

  $costBegin = microtime(true);

  foreach($arr as $item) {

  $sql = sprintf("INSERT INTO user_info (name, age) VALUES ( '%s', %d);", $item['name'], (int)$item['age']);

  if ($conn->query($sql) === TRUE) {

  echo "insert success";

  } else {

  echo "Error: " . $sql . "< br>" . $conn->error;

  }

  }

  $costEnd = microtime(true);

  $cost = round($costEnd - $costBegin, 3);

  var_dump($cost);

  $conn->close();

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

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

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

  INSERT INTO user_info (name, age) VALUES ('name1', 18), ('name2', 19);表示一次插入两条数据

  $arr = [

  [

  'name' => 'testname1',

  'age' => 18,

  ],

  [

  'name' => 'testname2',

  'age' => 19,

  ],

  [

  'name' => 'testname3',

  'age' => 18,

  ],

  // 此处省略

  ……

  ……

  ];

  $servername = "localhost";

  $port = 3306;

  $username = "username";

  $password = "password";

  $dbname = "mytestdb";

  // 创建连接

  $conn = new mysqli($servername, $username, $password, $dbname, $port);

  // 检测连接

  if ($conn->connect_error) {

  die("connect failed: " . $conn->connect_error);

  }

  $costBegin = microtime(true);

  if (!empty($arr)) {

  $sql = sprintf("INSERT INTO user_info (name, age) VALUES ");

  foreach($arr as $item) {

  $itemStr = '( ';

  $itemStr .= sprintf("'%s', %d", $item['name'], (int)$item['age']);

  $itemStr .= '),';

  $sql .= $itemStr;

  }

  // 去除最后一个逗号,并且加上结束分号

  $sql = rtrim($sql, ',');

  $sql .= ';';

  if ($conn->query($sql) === TRUE) {

  } else {

  echo "Error: " . $sql . "

  " . $conn->error;

  }

  }

  $costEnd = microtime(true);

  $cost = round($costEnd - $costBegin, 3);

  var_dump($cost);

  $conn->close();

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

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

关于mysql中怎么使用php批量插入数据就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯