我正在使用ADODB连接编写SQL语句以便在excel vba中提取数据。如何使用adodb编写sql查询来选择长度超过255个字符的数据
我的问题是,我有一个单元格它包含一个字符串超过255个字符。
我想知道是否有一种方法对我来说,继续使用ADODB连接选择具有超过255个字符
这是我使用的功能数据。
Public Function QueryRead(sqlArg As String) As Dictionary
Dim pConnection As ADODB.Connection
Set pConnection = New ADODB.Connection
With pConnection
.Provider = "Microsoft.Jet.OLEDB.4.0"
.ConnectionString = "Data Source=" & ActiveWorkbook.FullName & _
";Extended Properties=Excel 8.0;"
'.Provider = "MSDASQL"
'.ConnectionString = "Driver={Microsoft Excel Driver (*.xls)};" & _
"DBQ=" & App.Path & "\ExcelSrc.xls; "
.CursorLocation = adUseClient
.Open
End With
Dim pMap As New ADODB.Recordset
Dim sql As String
sql = sqlArg
Dim resultSet As New Dictionary
pMap.Open sql, pConnection
If pMap.RecordCount > 0 Then
Dim record As Variant
Dim counter As Integer
counter = 0
Do Until pMap.EOF
Dim resultRecord As Dictionary
Set resultRecord = New Dictionary
For Each record In pMap.fields
resultRecord.Add record.Name, record.value
Next
Dim index As String
index = CStr(counter)
resultSet.Add index, resultRecord
counter = counter + 1
pMap.MoveNext
Loop
End If
pMap.Close
pConnection.Close
Set QueryRead = resultSet
End Function
我这是怎么称呼它
Set resultSet = model.QueryRead("SELECT * FROM [Database$] WHERE [Level] = 2 AND [Item_No] = '" & itemNo & "'")
我的工作表被称为数据库,它有诸如等级和ITEM_NO列。
列公式之下的单元格之一具有超过255个字符的字符串。
请指教。
UPDATE
我想强调的是
a)其是萃取的是超过255个字符的限制各个场数据。意思就是说,在*的“SELECT * FROM”
二)它是超过255个字符
C未我的输入参数)这不是我的查询字符串超过255个字符
尝试使用'ADODB.Command'和数据绑定('Command.Parameters.Append Command.CreateParameter(text_index ,enum_type,enum_direction,大小,值)')。 – Passerby
你能给我一个更清晰的图片和答案吗?谢谢。 –