sql >> Database >  >> RDS >> Mysql

Meest efficiënte manier om rijen in de MySQL-database in te voegen

Hier is mijn "meerdere inserts"-code.

Het invoegen van 100k rijen duurde in plaats van 40 seconden slechts 3 seconden !!

public static void BulkToMySQL()
{
    string ConnectionString = "server=192.168.1xxx";
    StringBuilder sCommand = new StringBuilder("INSERT INTO User (FirstName, LastName) VALUES ");           
    using (MySqlConnection mConnection = new MySqlConnection(ConnectionString))
    {
        List<string> Rows = new List<string>();
        for (int i = 0; i < 100000; i++)
        {
            Rows.Add(string.Format("('{0}','{1}')", MySqlHelper.EscapeString("test"), MySqlHelper.EscapeString("test")));
        }
        sCommand.Append(string.Join(",", Rows));
        sCommand.Append(";");
        mConnection.Open();
        using (MySqlCommand myCmd = new MySqlCommand(sCommand.ToString(), mConnection))
        {
            myCmd.CommandType = CommandType.Text;
            myCmd.ExecuteNonQuery();
        }
    }
}

Het gemaakte SQL-statement ziet er als volgt uit:

INSERT INTO User (FirstName, LastName) VALUES ('test','test'),('test','test'),... ;

Bijwerken :Bedankt Salman A Ik heb MySQLHelper.EscapeString . toegevoegd om code-injectie te voorkomen die intern wordt gebruikt wanneer u parameters gebruikt.



  1. Hoe maak je een geneste tabel als database-object in Oracle?

  2. hoe selecteer je alleen een rij met een maximale reeks zonder een subquery te gebruiken?

  3. 3 manieren om de dagnaam van een datum te krijgen in SQL Server (T-SQL)

  4. Verhoog de VOTE-schijfgroep in ASM voor GI 12.2 Upgrade