sql >> Databasteknik >  >> RDS >> Mysql

Det effektivaste sättet att infoga rader i MySQL-databasen

Här är min "multiple inserts"-kod.

Infogningen av 100 000 rader tog istället för 40 sekunder bara 3 sekunder !!

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();
        }
    }
}

Den skapade SQL-satsen ser ut så här:

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

Uppdatera :Tack Salman A Jag lade till MySQLHelper.EscapeString för att undvika kodinjektion som används internt när du använder parametrar.



  1. Konvertera "datetimeoffset" till "smalldatetime" i SQL Server (T-SQL-exempel)

  2. hur man ställer in automatisk inkrementkolumn med sql-utvecklare

  3. Arbetar med JDBC och Spring

  4. Mysql 1050 Error Table finns redan när den faktiskt inte gör det