2017-01-30 13 views
0

ゴール:ピボットテーブルをソースDBテーブル(MS-ACCESS 2010)に直接接続します。ピボットテーブルをワークブック接続(ACCESS DB)に設定できません

ステータス:私はWorkbookConnectionをVBA経由でDBにセットアップできます。

オプション1:以下の2つのオプションを持つSet PvtTblにランタイムエラー(1004)を生成しようとする、しかし

WB.PivotCaches.Create(SourceType:=xlExternal, SourceData:=Conn) _ 
       .CreatePivotTable TableDestination:=Worksheets("ManHours").Range("A1"), _ 
       TableName:="OnePager" 

: 私はまた、コードを使用してPivotTableを作成することができています:

Set PvtTbl = PvtCache.CreatePivotTable(TableDestination:=Worksheets("ManHours").Range("A1"), TableName:="OnePager") 

オプション2

Set PvtTbl = Worksheets("ManHours").PivotTables.Add(PivotCache:=PvtCache, TableDestination:=Worksheets("ManHours").Range("A1"), TableName:="OnePager") 

マイコード

Option Explicit 

Sub Dynamic_PivotTable() 

Dim WB As Workbook 
Dim WBConns As WorkbookConnection 
Dim Conn As WorkbookConnection 
Dim ConnString As String 

Dim PvtTbl  As PivotTable 
Dim PvtCache As PivotCache 

Set WB = Workbooks("DynamicPivot_Connection.xlsm") '<-- Workbook is open 

' define ConnectionString 
ConnString = "OLEDB;Provider=Microsoft.ACE.OLEDB.12.0;Password="""";User ID=Admin;Data Source=J:\PMO\Resource allocation\DB\Resource_DB.accdb;" & _ 
      "Mode=Share Deny Write;Extended Properties="""";Jet OLEDB:System database="""";Jet OLEDB:Registry Path="""";Jet OLEDB:Database Password="""";" & _ 
      "Jet OLEDB:Engine Type=6;Jet OLEDB:Database Locking Mode=0;Jet OLEDB:Global Partial Bulk Ops=2;Jet OLEDB:Global Bulk Transactions=1;" & _ 
      "Jet OLEDB:New Database Password="""";Jet OLEDB:Create System Database=False;Jet OLEDB:Encrypt Database=False;" & _ 
      "Jet OLEDB:Don't Copy Locale on Compact=False;Jet OLEDB:Compact Without Replica Repair=False;Jet OLEDB:SFP=False;Jet OLEDB:Support Complex Data=False;" & _ 
      "Jet OLEDB:Bypass UserInfo Validation=False" 

' loop through all Workbook connections and delete all except "Resource_DB" 
For Each WBConns In WB.Connections 
    Select Case WBConns.Name 
     Case "Resource_DB" 
      Set Conn = WBConns 
     Case Else 
      WBConns.Delete   
    End Select 
Next WBConns 

If Conn Is Nothing Then 
    Set Conn = WB.Connections.Add("Resource_DB", "Resource DB Full Data Set", ConnString, "Select * from MergedDBTbl", 3) 
End If 

' set the Pivot Cache to update Workbook connection 
Set PvtCache = WB.PivotCaches.Add(xlExternal, Conn) 

' add this line in case the Pivot table doesn't exit >> first time running this Macro 
On Error Resume Next 
Set PvtTbl = Worksheets("ManHours").PivotTables("OnePager") ' check if "OnePager" Pivot Table already created (in past runs of this Macro) 

On Error GoTo 0 
If PvtTbl Is Nothing Then 

    ' create a new Pivot Table in "ManHours" sheet, start from Cell A1     
    WB.PivotCaches.Create(SourceType:=xlExternal, SourceData:=Conn) _ 
       .CreatePivotTable TableDestination:=Worksheets("ManHours").Range("A1"), TableName:="OnePager" 

    ' create a new Pivot Table in "Pivot" sheet, start from Cell A1 ******* LINE BELOW PRODUCES AN ERROR ****** 
    Set PvtTbl = Worksheets("ManHours").PivotTables.Add(PivotCache:=PvtCache, TableDestination:=Worksheets("ManHours").Range("A1"), TableName:="OnePager") 


    ' ******* LINE BELOW PRODUCES AN ERROR ****** 
    Set PvtTbl = PvtCache.CreatePivotTable(TableDestination:=Worksheets("ManHours").Range("A1"), TableName:="OnePager") 
    'Create the headings and row and column orientation and all of your other settings here 

Else 
    ' just refresh the Pivot cache with the updated Range (data in "ManHours" worksheet) 
    PvtTbl.ChangePivotCache PvtCache '<--- ALSO PRODUCES AN ERROR ! 
    PvtTbl.RefreshTable 
End If 

End Sub 
+0

ここをクリックしてください - https://www.thespreadsheetguru.com/blog/2014/9/27/vba-guide-excel-pivot-tables - ピボットテーブルを作成するためにピボットテーブルを使用しています - 'Set pvt = pvtCache.CreatePivotTable'。それがあなたと一緒に働くかどうかは分かりません。 – Vityata

+0

これらの行を順番に実行していますか? – Rory

+0

@Rour ofcourseではなく、私はそのたびに2つのコメントをして、3回目を試みます。 1つだけは動作しますが、使いたい方法ではありません。 –

答えて

2

あなたが使用する必要があります。

Set PvtCache = WB.PivotCaches.Create(xlExternal, Conn) 

いうより:

Set PvtCache = WB.PivotCaches.Add(xlExternal, Conn) 

そして、ブックを開いたときに、ピボットテーブルが自動的に更新させます、使用:

PvtCache.RefreshOnFileOpen = True 
関連する問題