Home  >  Article  >  Database  >  How to batch insert data in mysql

How to batch insert data in mysql

coldplay.xixi
coldplay.xixiOriginal
2020-12-14 16:21:4633837browse

Mysql batch insert data method: 1. Loop insertion, syntax format "for($i=1;$i<=condition;$i){//insert statement}"; 2. Reduce connection resources , splice a sql; 3. Use stored procedures; 4. Use "MYSQL LOCAL_INFILE".

How to batch insert data in mysql

The operating environment of this tutorial: windows7 system, mysql8.0.22 version, thinkpad t480 computer.

Mysql batch insert data method:

Method 1: Loop insertion

This is also the most common way, if The amount of data is not very large and can be used, but the resources to connect to the database will be consumed every time.

The general thinking is as follows

(I write pseudo code here, the specific writing can be combined with your own business logic or framework syntax)

for($i=1;$i<=100;$i++){
$sql = 'insert...............';
//querysql
}
foreach($arr as $key => $value){
$sql = 'insert...............';
//querysql
}
while($i <= 100){
$sql = 'insert...............';
//querysql
$i++
}

Because it is too common and not difficult at the same time At the same time, it is not what I am mainly writing today, so I won’t say much here

Method 2: Reduce connection resources and splice a sql

The pseudo code is as follows

//这里假设arr的key和数据库字段同步,其实大多数框架中在php操作数据库的时候都是这么设计的
$arr_keys        = array_keys($arr);
$sql             = 'INSERT INTO tablename (' . implode(',' ,$arr_keys) . ') values';
$arr_values      = array_values($arr);
$sql             .= " ('" . implode("','" ,$arr_values) . "'),";
$sql             = substr($sql ,0 ,-1);
//拼接之后大概就是  INSERT INTO tablename ('username','password') values 
('xxx','xxx'),('xxx','xxx'),('xxx','xxx'),('xxx','xxx'),('xxx','xxx'),('xxx','xxx')
.......
//querysql

It is not a big problem to write 10,000 normal inserts like this, unless the data is very long, it is enough to handle ordinary batch insertion, such as: batch generation of card numbers, batch generation of random codes, etc.

Method 3: Use stored procedures

I happen to use this in my hand to pay the sql. You can combine the specific business logic yourself.

delimiter $$$
create procedure zqtest()
begin
declare i int default 0;
set i=0;
start transaction;
while i<80000 do
//your insert sql 
set i=i+1;
end while;
commit;
end
$$$
delimiter;
call zqtest();

This is just a test code, you can define the specific parameters yourself

I am inserting 80,000 items at a time. Although it is not much, the amount of data in each item is large, and there are many varchar4000 and text field

takes 6.524s

Method 4: Use MYSQL LOCAL_INFILE

I am currently using this, so by the way, I also put the pdo code Post it for your reference

//设置pdo开启MYSQL_ATTR_LOCAL_INFILE
/*hs96.cn@gmail.com
public function pdo_local_info ()
{
     global $system_dbserver;
     $dbname  = 'hs96.cn@gmail.com';
     $ip      = 'hs96.cn@gmail.com';
     $user    = 'hs96.cn@gmail.com';
     $pwd     = 'hs96.cn@gmail.com';
     $dsn     = 'mysql:dbname=' . $dbname . ';host=' . $ip . ';port=3306';
     $options = [PDO::MYSQL_ATTR_LOCAL_INFILE => true];
     $db      = new PDO($dsn ,$user ,$pwd ,$options);
     return $db;
 }
//伪代码如下
public function test(){
     $arr_keys         = array_keys($arr);
$root_dir         = $_SERVER["DOCUMENT_ROOT"] . '/';
$my_file          = $root_dir . "hs96.cn@gmail.com/sql_cache/" . $order['OrderNo'] . '.sql';
$fhandler         = fopen($my_file,'a+');
if ($fhandler) {
    $sql = implode("\t" ,$arr);
      $i   = 1;
      while ($i <= 80000)
      {
          $i++;
          fwrite($fhandler ,$sql . "\r\n");
      }
      $sql = "LOAD DATA local INFILE '" . $myFile . "' INTO TABLE ";
      $sql .= "tablename (" . implode(',' ,$arr_keys) . ")";
      $pdo = $this->pdo_local_info ();
      $res = $pdo->exec($sql);
      if (!$res) {
           //TODO 插入失败
      }
      @unlink($my_file);
  }
}

More related free learning recommendations:mysql tutorial(Video)

The above is the detailed content of How to batch insert data in mysql. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn