집 >데이터 베이스 >MySQL 튜토리얼 >더 빠른 데이터 관리를 위해 MySQL 행 삽입을 어떻게 최적화할 수 있습니까?
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(); } } }
이 방법을 활용하여 , 3초 내에 10만 행 삽입을 완료할 수 있습니다. 이는 원래 40초에 비해 대폭 향상된 것입니다. 아래와 같이 생성된 SQL 문은 단일 문에 여러 행을 삽입하는 방법을 보여줍니다.
INSERT INTO User (FirstName, LastName) VALUES ('test','test'),('test','test'),... ;
데이터 무결성을 보장하고 코드 삽입 공격을 방지하기 위해 MySqlHelper.EscapeString 메서드를 사용하여 특수 문자를 이스케이프합니다. 삽입된 데이터 내에서.
위 내용은 더 빠른 데이터 관리를 위해 MySQL 행 삽입을 어떻게 최적화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!