传递给 ADODB 的查询长度是否有限制?

Is there a limit to the query length being passed to ADODB?

我目前正在测试一个框架,该框架将 SQL 查询存储在 excel 工作簿的单元格中,然后将单元格值传递给变量。然后通过 rs.Open query, cn 执行此变量,其中:

Dim rs As ADODB.Recordset 
Dim cn As ADODB.Connection 

我已经为 "query" 尝试了这些:

Dim query as String
Dim query as Variant

甚至使用固定长度的查询:

Dim query as String * 9999

在处理查询字符串的输出时,它在 8000 左右截断。Google 对我来说太短了,所以我来这里寻求答案。变量可以传递给 recordset.Open() 的内容是否有特定限制?

注意:我用于此特定查询的连接字符串是: ConnectionString = "User ID=User;Password=PW;Data Source=DB;Provider=OraOLEDB.Oracle"

但是如果您知道 Oracle、NetezzaSQL 或 MS SQL 服务器 (SQLOLEDB.1) 是否存在系统特定限制,请告诉我。我需要指定每个查询的限制,以便定义需要将哪些新查询转换为存储过程。

这里是代码的要点:

Sub RunQueryTable()

Dim cn As ADODB.Connection
Dim RS As ADODB.Recordset
Dim iCols As Integer
Dim DB As String, User As String, PW As String
Dim SQLTable As Worksheet
Dim ConnectionString as String
Dim query As String 'Or Dim query As Variant 'Or Dim query As String * 9999
Dim i As Long
etc, etc.

Set SQLTable = Sheet32
Set cn = New ADODB.Connection
Set RS = New ADODB.Recordset

DB = _____
User = ______
PW = ____

ConnectionString = "User ID=" & User & _
                   ";Password=" & PW & _
                   ";Data Source=" & DB & _
                   ";Provider=OraOLEDB.Oracle"

query = SQLTable.Cells(i, 3).Text

cn.Open (ConnectionString)
RS.CursorType = adOpenForwardOnly
RS.Open (query), cn

For iCols = 0 To RS.Fields.count - 1
    Worksheets("Output").Cells(1, iCols + 1).Value = RS.Fields(iCols).Name
Next
Worksheets("Output").Cells(2, "A").CopyFromRecordset RS

RS.Close
cn.Close

End Sub

我从 VBA 得到的具体错误是:"ORA-00923: FROM keyword not found where expected" 因为查询被中断了。

这是你的问题:

query = SQLTable.Cells(i, 3).Text

考虑:

Range("A1").Value=string(12000,"*")
? len(range("a1").value) '>> 12000
? len(range("a1").text) '>> 8221