私は以前にこのサイトを使用していましたが、その後は通常動作するものを構築しました。新しいSQLスクリプトでは動作しません(ただし、SQLスクリプトは機能します)。私はVBAコードではうまくいかず、本当にそれを理解していません.... !!!SQLコードとVBA
誰か助けてもらえますか?私はエラー "実行時エラー '3704'、操作is notオブジェクトが閉じるときに許可されていません")。 仕上げの前にどのように閉じているのかわかりません!
私はこれには2つのセクションがあります。 モジュール1 - 下の両方 を実行するために、SQLコードが含まれている - 接続プロパティ モジュール2含まれています
モジュール1:
Public Const DBName As String =
Public Const strServer As String = "RMSSQL"
Public Const connecString1 As String = "Provider=SQLOLEDB.1"
Public Const connecString2 As String = ";Initial Catalog="
Public Const connecString3 As String = ";DataSource="
Public passSQL As ADODB.Connection
Public myrst As ADODB.Recordset
Public Function runTheQuery(sqlQuery, DBaseName)
'connect
Dim strConnect As String
strConnect = "Driver={SQL Server}; Server=" & strServer & ";Database=" & DBaseName & ";Trusted_Connection=yes; "
Set passSQL = New ADODB.Connection
passSQL.ConnectionString = strConnect
passSQL.CursorLocation = adUseClient
passSQL.CommandTimeout = 0
passSQL.Open
'create recordset
Dim aRst As ADODB.Recordset
Set aRst = New ADODB.Recordset
With aRst
.activeconnection = passSQL
.CursorLocation = adUseClient
.CursorType = adOpenStatic
.LockType = adLockBatchOptimistic
'run sql query
.Open sqlQuery
.activeconnection = Nothing
End With
Set myrst = aRst
'close
passSQL.Close
End Function
をモジュール2:
Sub simplequery()
runTheQuery "declare @Portname varchar(60) " & _
"set @Portname = " & "'" & Range("G10").Value & "'" & _
"SELECT SUM(M.TIV) as TIV " & _
"FROM (select port.PORTNAME, lcvg.LOCID, lcvg.LOSSTYPE, prop.OCCSCHEME, prop.OCCTYPE, MAX(lcvg.VALUEAMT) TIV " & _
"from accgrp ac " & _
"inner join Property prop on prop.ACCGRPID = ac.ACCGRPID " & _
"inner join Address addr on addr.AddressID = prop.AddressID " & _
"inner join loccvg lcvg on lcvg.LOCID = prop.LOCID " & _
"inner join portacct pa on pa.ACCGRPID = ac.ACCGRPID " & _
"inner join portinfo port on port.PORTINFOID = pa.PORTINFOID " & _
"where port.PORTNAME = @Portname " & _
"group by port.PORTNAME, lcvg.LOCID, lcvg.LOSSTYPE, prop.OCCSCHEME, prop.OCCTYPE, lcvg.VALUEAMT) M " & _
"GROUP BY M.PORTNAME; ", Sheets("Modelled Results - 1 of 2").Range("g9").Value
Sheets("DataDumps").Range("A1").Select
'Headers
For col = 0 To myrst.Fields.Count - 1
ActiveCell.Offset(0, col).Value = myrst.Fields(col).Name
Next
'Paste recordset
Range("A1").CopyFromRecordset myrst
End Sub
私はデバッグする場合、それが強調表示され、このです:このように更新
'Paste recordset
Range("A1").CopyFromRecordset myrst
:
モジュール1:
'Public Const DBName As String =
Public Const strServer As String = "RMSSQL"
Public Const connecString1 As String = "Provider=SQLOLEDB.1"
Public Const connecString2 As String = ";Initial Catalog="
Public Const connecString3 As String = ";DataSource="
Public passSQL As ADODB.Connection
Public myrst As ADODB.Recordset
Function runTheQuery(ByVal SQLQuery As String, ByVal DBName As String, ByRef MyRange As Range)
'Connect
Dim strConnect As String
strConnect = "Driver={SQL Server}; Server=" & strServer & ";Database=" & DBaseName & ";Trusted_Connection=yes; "
Set passSQL = New ADODB.Connection
passSQL.ConnectionString = strConnect
passSQL.CursorLocation = adUseClient
passSQL.CommandTimeout = 0
passSQL.Open
'create recordset
Dim aRst As ADODB.Recordset
Set aRst = New ADODB.Recordset
With aRst
.activeconnection = passSQL
.CursorLocation = adUseClient
.CursorType = adOpenStatic
.LockType = adLockBatchOptimistic
'run sql query
.Open SQLQuery
.activeconnection = Nothing
End With
Set myrst = aRst
'close
passSQL.Close
Sheets("DataDumps").Range("A1").Select
'Headers
For col = 0 To myrst.Fields.Count - 1
ActiveCell.Offset(0, col).Value = myrst.Fields(col).Name
Next
'Paste recordset
Range("A1").CopyFromRecordset myrst
MyRange.CopyFromRecordset myrst
myrst.Close
End Function
モジュール2: をSub simplequery()
runTheQuery "declare @Portname varchar(60) " & _
"set @Portname = " & "'" & Range("G10").Value & "'" & _
"SELECT SUM(M.TIV) as TIV " & _
"FROM (select port.PORTNAME, lcvg.LOCID, lcvg.LOSSTYPE, prop.OCCSCHEME, prop.OCCTYPE, MAX(lcvg.VALUEAMT) TIV " & _
"from accgrp ac " & _
"inner join Property prop on prop.ACCGRPID = ac.ACCGRPID " & _
"inner join Address addr on addr.AddressID = prop.AddressID " & _
"inner join loccvg lcvg on lcvg.LOCID = prop.LOCID " & _
"inner join portacct pa on pa.ACCGRPID = ac.ACCGRPID " & _
"inner join portinfo port on port.PORTINFOID = pa.PORTINFOID " & _
"where port.PORTNAME = @Portname " & _
"group by port.PORTNAME, lcvg.LOCID, lcvg.LOSSTYPE, prop.OCCSCHEME, prop.OCCTYPE, lcvg.VALUEAMT) M " & _
"GROUP BY M.PORTNAME ", Sheets("Modelled Results - 1 of 2").Range("g9").Value, Range("a1")
End Sub
こんにちは、私はあなたが言っていることを得るが、どのようにこれをクエリに実装するか分からない? – diggles
コピーして見せてください。とても感謝しております!最高のお礼、James – diggles
解決策1を試してください(全体的に簡単です)。あなたが試したこととそれが返されたエラーメッセージを表示するためにあなたの質問を編集することができない場合。うまくいけば、私は助けるためにもっと時間があります。 –