作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 Excel 中,我有一列 ID。我想根据 ID 列中的值从表中选择值。到目前为止,我已经得到了这个,其中 ws.Cells(i,10) 指的是 K 列中每行的值。
With ActiveSheet.ListObjects.Add(SourceType:=0, Source:=Array(Array( _
"ODBC;DSN=xxxx;Description=xxxxx;UID=xxx;APP=2007 Microsoft Office system;WSID=xxx" _
), Array("56;DATABASE=xxx;Trusted_Connection=Yes")), Destination:=Range( _
"$M$3")).QueryTable
For i = 1 To 691
sText = "SELECT Instrument.ID, Instrument.MATURITY FROM xxxx.dbo.Instrument Instrument WHERE Instrument.ID=" & ws.Cells(i, 10).Value & ""
.CommandText = Array(sText)
Next
End With
我在 sText 行上收到错误“424”,错误消息“需要对象”。
我也有预感这不是最好的方法。必须有一个更简单的设置来运行具有列中 WHERE 条件的 SQL。
感谢您的帮助!
最佳答案
我几乎肯定 iDevlop 是正确的 - 您尚 undefined variable ws,这会导致“需要对象”错误消息。
无论如何,您可能更喜欢这个解决方案:
Dim IDs as String
Dim ws As Worksheet
Set ws = ActiveSheet
IDs = Join(WorksheetFunction.Transpose( _
ws.Range(ws.Cells(1, 10), ws.Cells(691, 10))), ",")
.CommandText = "SELECT ... FROM ... WHERE Instrument.ID in (" + IDs + ")"
无需循环。
关于sql - 从 VBA 调用 SQL 时的动态 WHERE 条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7878029/
我是一名优秀的程序员,十分优秀!