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
逐语句调试出现这个错误,截图如下。 展开
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
逐语句调试出现这个错误,截图如下。 展开
展开全部
连接字符串有问题,正确的格式如下:
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)
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)
展开全部
Dim cn As New ADODB.Connection '定义数据链接对象 ,保存连接数据库信息;请先添加ADO引用
Dim rs As New ADODB.Recordset '定义记录集对象,保存数据表
=======
定义中不要加New
之后用:set cn=new adodb.connection
set rs=new adodb.recordset
Dim rs As New ADODB.Recordset '定义记录集对象,保存数据表
=======
定义中不要加New
之后用:set cn=new adodb.connection
set rs=new adodb.recordset
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你是不是没有先添加ADO引用?
追问
同时感谢所有给出意见的同志们,谢谢了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询