我已经读过很多关于这个的问题,但是我找不到足够快的问题。我认为有更好的方法可以将许多行插入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行只用了3秒,而不是40秒!
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
为了避免在使用参数时在内部使用代码注入。
只需用双撇号替换“测试”中的撇号,就可以了。“ test” ==>“ test” .Replace(“'”,“''”)
你可能想使用
MySQLHelper.EscapeString
上"test"
。@fubo应该是。我猜想它使用相同或相似的代码来转义参数值。
现在,您在内存中创建了一个很长的字符串。
有没有一种方法可以对此进行参数化并获得相同的结果?我团队中的某些人告诉我,这种方法无效,因为它使您容易进行SQL注入。您将如何保护该声明不被注入?由于性能原因,我需要能够进行多次插入。