c# - 将行插入 MySQL 数据库的最有效方法

标签 c# mysql performance

我已经阅读了很多关于此的问题,但我找不到足够快的问题。我认为有更好的方法可以将大量行插入 MySQL 数据库

我使用以下代码将 100k 插入我的 MySQL 数据库:

public static void CSVToMySQL()
{
    string ConnectionString = "server=192.168.1xxx";
    string Command = "INSERT INTO User (FirstName, LastName ) VALUES (@FirstName, @LastName);";
    using (MySqlConnection mConnection = new MySqlConnection(ConnectionString))
    {
        mConnection.Open();

        for(int i =0;i< 100000;i++) //inserting 100k items
        using (MySqlCommand myCmd = new MySqlCommand(Command, mConnection))
        {
            myCmd.CommandType = CommandType.Text;
            myCmd.Parameters.AddWithValue("@FirstName", "test");
            myCmd.Parameters.AddWithValue("@LastName", "test");
            myCmd.ExecuteNonQuery();
        }
    }
}

这需要 100k 行大约 40 秒。我怎样才能使它更快或更有效?

通过 DataTable/DataAdapter 或一次插入多行可能会更快:

INSERT INTO User (Fn, Ln) VALUES (@Fn1, @Ln1), (@Fn2, @Ln2)...

由于安全问题,我无法将数据加载到文件和 MySQLBulkLoad 中。

最佳答案

这是我的“多次插入”代码。

插入 100k 行只用了 40 秒而不是 3 秒!!

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

创建的 SQL 语句如下所示:

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

更新:感谢Salman A我添加了 MySQLHelper.EscapeString 以避免在您使用参数时内部使用的代码注入(inject)。

关于c# - 将行插入 MySQL 数据库的最有效方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25323560/

相关文章:

c# - 从客户端消息检查器访问 ClientCredential 属性

php - 如果日期和时间不是TIMESTAMPDIFF格式那么如何用mysql找到间隔?

python - 连接和存储长位串的最有效方法是什么?

c# - 技术实现多态性但节省 4 个字节

c# - 如何为 Azure AD 创建和使用刷新 token

python - 如何将 MySQL fetchall() 结果迭代到 tinter 列表框和中心结果中

C# CopyFromScreen 问题

php - 对于 PHP/MYSQL,这 2 种方法中哪一种最有效

c# - 我可以在后台运行多个慢速进程,以便可以并行运行多个任务吗?

mysql - 错误 : 'Can' t connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)' -- Missing/var/run/mysqld/mysqld. socks