sql >> Databáze >  >> RDS >> Mysql

Jaký je nejlepší způsob vložení více řádků do PHP PDO MYSQL?

Máte alespoň tyto dvě možnosti:

$rows = [(1,2,3), (4,5,6), (7,8,9) ... ];

$sql = "insert into `table_name` (col1, col2, col3) values (?,?,?)";

$stmt = $db->prepare($sql);

foreach($rows as $row)
{
    $stmt->execute($row);
}

OR:

$rows = [(1,2,3), (4,5,6), (7,8,9) ... ];

$sql = "insert into `table_name` (col1, col2, col3) values ";

$paramArray = array();

$sqlArray = array();

foreach($rows as $row)
{
    $sqlArray[] = '(' . implode(',', array_fill(0, count($row), '?')) . ')';

    foreach($row as $element)
    {
        $paramArray[] = $element;
    }
}

// $sqlArray will look like: ["(?,?,?)", "(?,?,?)", ... ]

// Your $paramArray will basically be a flattened version of $rows.

$sql .= implode(',', $sqlArray);

$stmt = $db->prepare($sql);

$stmt->execute($paramArray);

Jak můžete vidět, první verze obsahuje mnohem jednodušší kód; avšak druhá verze provede dávkové vložení. Dávkové vložení by mělo být rychlejší, ale souhlasím s @BillKarwin že rozdíl ve výkonu nebude ve velké většině implementací zaznamenán.



  1. Použití fork v Ruby on Rails pro vytvoření paralelního procesu

  2. „Připojit“ aplikaci rails k již existující databázi MySQL?

  3. Chyba SQLAlchemy DELETE způsobená pomalou zátěží A dynamickou verzí stejného vztahu

  4. Nový způsob kopírování souborů v SQL Server 2019