VBA提示自动化错误,求高手解答。。。

Sublianjian_sql2000()'定义过程名称DimiAsInteger,jAsInteger,shtAsWorksheet'i,j为整数变量;sht为exce... Sub lianjian_sql2000() '定义过程名称
Dim i As Integer, j As Integer, sht As Worksheet 'i,j为整数变量;sht 为excel工作表对象变量,指向某一工作表
Dim cn As New ADODB.Connection '定义数据链接对象 ,保存连接数据库信息;请先添加ADO引用
Dim rs As New ADODB.Recordset '定义记录集对象,保存数据表
Dim strCn As String, strSQL As String '字符串变量
strCn = "Provider=sqloledb;Server=127.0.0.1;Database=cw;Uid=sa;Pwd=;" '定义数据库链接字符串
'下面的语句将读取数据表数据,并将它保存到excel工作表中:
strSQL = "select cWhCode, cWhName,WA.cWhValueStyle from dbo.Warehouse WA" '定义SQL查询令字符串
cn.Open strCn '与数据库建立连接,如果成功,返回连接对象cn
rs.Open strSQL, cn '执行strSQL所含的SQL命令,结果保存在rs记录集对象中
Set sht = Worksheets("Sheet1") '把sht指向当前工作簿的sheet1工作表
i = 1
Do While Not rs.EOF '当数据指针未移到记录集末尾时,循环下列操作
sht.Cells(i, 1) = rs("cWhCode") '把当前记录的字段1的值保存到sheet1工作表的第i行第1列
sht.Cells(i, 2) = rs("cWhName") '
sht.Cells(i, 3) = rs("WA.cWhValueStyle")
rs.MoveNext
i = i + 1
Loop
rs.Close
cn.Close '关闭数据库链接,释放资源
Set sht = Nothing
End Sub
逐语句调试出现这个错误,截图如下。
展开
 我来答
爱栀竹的人
推荐于2016-05-26 · TA获得超过1352个赞
知道大有可为答主
回答量:1743
采纳率:0%
帮助的人:982万
展开全部
连接字符串有问题,正确的格式如下:
1 用机器名的连接
Provider=SQLOLEDB;Data Source=machineName;Initial Catalog=dbname;User ID=sa;Password=pass;
2 用ip地址的连接
Provider=SQLOLEDB; Data Source=xx.xx.xx.xx,1433; Network Library=DBMSSOCN; Initial Catalog=dbname;User ID=sa;Password=pass;

'下面一句是错的
Set sht = Worksheets("Sheet1") '把sht指向当前工作簿的sheet1工作表
'修改后的代码
Dim oXl As Excel.Application

Set oXl = GetObject("你的含路径信息的excel文件", "Excel.Application")
Set sht = oxl.Workbooks(1).Worksheets(1)
Excel开发
2013-02-19 · TA获得超过2912个赞
知道大有可为答主
回答量:1989
采纳率:53%
帮助的人:1002万
展开全部
Dim cn As New ADODB.Connection '定义数据链接对象 ,保存连接数据库信息;请先添加ADO引用
Dim rs As New ADODB.Recordset '定义记录集对象,保存数据表
=======
定义中不要加New
之后用:set cn=new adodb.connection
set rs=new adodb.recordset
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
太极健1969
2013-02-19 · TA获得超过9030个赞
知道大有可为答主
回答量:8668
采纳率:69%
帮助的人:3559万
展开全部
你是不是没有先添加ADO引用?
追问
同时感谢所有给出意见的同志们,谢谢了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式