SQLクエリの結果をExcelシート(Excel 2007)に取得する方法を示すVBAコードスニペットをMSDNからコピーしています。
Sub GetDataFromADO()
'Declare variables'
Set objMyConn = New ADODB.Connection
Set objMyCmd = New ADODB.Command
Set objMyRecordset = New ADODB.Recordset
'Open Connection'
objMyConn.ConnectionString = "Provider=SQLOLEDB;Data Source=localhost;User ID=abc;Password=abc;"
objMyConn.Open
'Set and Excecute SQL Command'
Set objMyCmd.ActiveConnection = objMyConn
objMyCmd.CommandText = "select * from myTable"
objMyCmd.CommandType = adCmdText
objMyCmd.Execute
'Open Recordset'
Set objMyRecordset.ActiveConnection = objMyConn
objMyRecordset.Open objMyCmd
'Copy Data to Excel'
ActiveSheet.Range("A1").CopyFromRecordset (objMyRecordset)
End Sub
参照として、Microsoft ActiveX Data Objects2.1Libraryをすでに追加しました。そして、このデータベースにアクセスできます。
このサブルーチンを実行すると、エラーが発生します。
実行時エラー3704:オブジェクトが閉じているときの操作は許可されていません。
声明について:
ActiveSheet.Range("A1").CopyFromRecordset (objMyRecordset)
なぜですか?
ありがとう。