最佳化 MySQL 資料庫的行插入
MySQL 資料庫的行插入效能對於高效的資料管理至關重要。使用單獨插入查詢的傳統方法可能非常耗時。這是一種高度最佳化的方法,可以顯著加快插入過程。
這種改進的方法不是執行大量單獨的 INSERT 語句,而是利用單一多行 INSERT 語句同時插入多行。透過避免重複開銷並創建大量要插入的數據,資料庫可以更有效地處理操作。
下面的程式碼示範了此技術:
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(); } } }
利用此方法,10萬行的插入可以在3秒內完成,比原來的40秒有了巨大的進步。產生的SQL語句如下所示,示範了單一語句插入多行:
INSERT INTO User (FirstName, LastName) VALUES ('test','test'),('test','test'),... ;
為了確保資料完整性,防止程式碼注入攻擊,採用了MySqlHelper.EscapeString方法對特殊字元進行轉義在插入的數據內。
以上是如何最佳化 MySQL 行插入以加快資料管理速度?的詳細內容。更多資訊請關注PHP中文網其他相關文章!