>데이터 베이스 >MySQL 튜토리얼 >더 빠른 데이터 관리를 위해 MySQL 행 삽입을 어떻게 최적화할 수 있습니까?

더 빠른 데이터 관리를 위해 MySQL 행 삽입을 어떻게 최적화할 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-03 17:56:11736검색

How Can I Optimize MySQL Row Insertion for Faster Data Management?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.