>데이터 베이스 >MySQL 튜토리얼 >VBA를 사용하여 대규모 Excel 데이터 세트를 MS Access로 가져오는 성능을 어떻게 향상시킬 수 있습니까?

VBA를 사용하여 대규모 Excel 데이터 세트를 MS Access로 가져오는 성능을 어떻게 향상시킬 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-04 17:58:38518검색

How Can I Improve the Performance of Importing Large Excel Datasets into MS Access Using VBA?

Excel VBA를 사용하여 MS Access로 데이터 가져오기: 성능 개선

Excel에서 MS Access 테이블로 데이터를 내보낼 때 성능이 저하될 수 있습니다. 많은 수의 레코드를 처리할 때 문제가 발생합니다. 그러나 프로세스를 최적화하는 방법이 있습니다.

제공된 VBA 코드는 각 행을 반복하여 Access 테이블에 데이터를 삽입합니다. 이는 광범위한 데이터 세트의 경우 시간이 많이 걸릴 수 있는 반복 프로세스입니다. 성능을 향상하려면 대량 삽입에 단일 SQL INSERT 문을 사용하는 것이 좋습니다.

SQL INSERT를 사용하여 최적화된 코드:

Public Sub DoTrans()

  Set cn = CreateObject("ADODB.Connection")
  dbPath = Application.ActiveWorkbook.Path & "\FDData.mdb"
  dbWb = Application.ActiveWorkbook.FullName
  dbWs = Application.ActiveSheet.Name
  scn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & dbPath
  dsh = "[" & Application.ActiveSheet.Name & "$]"
  cn.Open scn

  ssql = "INSERT INTO fdFolio ([fdName], [fdOne], [fdTwo]) "
  ssql = ssql & "SELECT * FROM [Excel 8.0;HDR=YES;DATABASE=" & dbWb & "]." & dsh

  cn.Execute ssql

End Sub

구현:

  • 위 코드는 다음을 사용하여 Access 데이터베이스에 대한 연결을 설정합니다. ADODB.Connection.
  • 지정된 필드 이름을 사용하여 fdFolio 테이블에 데이터를 삽입하는 SQL INSERT 문을 구성합니다.
  • Execute 메서드는 SQL 문을 실행하여 대량 삽입 작업을 수행합니다.

이 최적화된 코드를 사용하면 각 행을 반복할 필요가 없어 대규모 데이터 세트의 성능이 크게 향상됩니다.

위 내용은 VBA를 사용하여 대규모 Excel 데이터 세트를 MS Access로 가져오는 성능을 어떻게 향상시킬 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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