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
구현:
이 최적화된 코드를 사용하면 각 행을 반복할 필요가 없어 대규모 데이터 세트의 성능이 크게 향상됩니다.
위 내용은 VBA를 사용하여 대규모 Excel 데이터 세트를 MS Access로 가져오는 성능을 어떻게 향상시킬 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!