| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1705 人关注过本帖, 1 人收藏
标题:用ADO对象加载mdb数据库出错
只看楼主 加入收藏
czqnazz00
Rank: 2
等 级:论坛游民
帖 子:38
专家分:34
注 册:2009-7-16
结帖率:100%
收藏(1)
已结贴  问题点数:20 回复次数:7 
用ADO对象加载mdb数据库出错
最近用到ListView控件,用ADO加载access数据库文件出错,请大虾给予指点.
Dim rs1 As New ADODB.Recordset
Dim rs2 As New ADODB.Recordset
Dim i As Integer
Dim itmX As ListItem   '声明一个ListItem对象
Dim MyIcon As Integer    '声明一个整型变量
Dim Mystr, MyMsg As String  '声明字符串变量
Private Sub Command4_Click()
    Unload Me
End Sub
Private Sub Form_Load()
    Adodc1.ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & App.Path & "\db_Exp.mdb;Persist Security Info=False"
    rs1.Open "tb_user", cnn, adOpenKeyset, adLockOptimistic '打开数据对象
    For i = 4 To Check1.UBound
        '向控件中添加字段
        Check1(i).Caption = rs1.Fields(i).Name
    Next i
    rs1.Close
    rs2.Open "select * from tb_user", cnn, adOpenStatic
    If rs2.RecordCount > 0 Then
        rs2.MoveFirst
        '向ListView中添加图片
        Do While rs2.EOF = False
            Mystr = rs2.Fields("user_name")
            MyIcon = Val(Right(rs2.Fields("user_tx"), Val(Len(rs2.Fields("user_tx")) - 2)))
            Set itmX = ListView1.ListItems.Add(, , Mystr, MyIcon)
            rs2.MoveNext
        Loop
    End If
    rs2.Close
End Sub
Private Sub Command1_Click()     '全选
    For i = 4 To Check1.UBound
        Check1(i).Value = 1
    Next i
End Sub
Private Sub Command2_Click()     '全不选
    For i = 4 To Check1.UBound
        Check1(i).Value = 0
    Next i
End Sub
Private Sub Command3_Click()     '为操作员设置权限
    Adodc1.RecordSource = "select * from tb_user where user_name ='" + ListView1.SelectedItem + "'"
    Adodc1.Refresh
    If Adodc1.Recordset.RecordCount > 0 Then
        For i = 4 To Check1.UBound
            Adodc1.Recordset.Fields(i) = Check1(i).Value
        Next i
        Adodc1.Recordset.Update
        Adodc1.Refresh
        MsgBox "操作员权限设置成功!", , "信息提示"
    End If
End Sub
Private Sub ListView1_Click() '查看操作员权限
    Adodc1.RecordSource = "select * from tb_user where user_name ='" + ListView1.SelectedItem + "'"
    Adodc1.Refresh
    If Adodc1.Recordset.RecordCount > 0 Then
        For i = 4 To Check1.UBound
            If Adodc1.Recordset.Fields(i) = "" Then
                Check1(i).Value = 0
            Else
                Check1(i).Value = Adodc1.Recordset.Fields(i)
            End If
        Next i
        Adodc1.Recordset.Update '更新数据记录
        Adodc1.Refresh
    End If
End Sub
Public Function cnn() As ADODB.Connection     '定义函数
    Set cnn = New ADODB.Connection
    cnn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & App.Path & "\db_Exp.mdb;Persist Security Info=False"
End Function

运行后提示:实时错误'-2147024770(8007007e)':自动化错误

这两条语句不能执行
Set cnn = New ADODB.Connection
Adodc1.Refresh
搜索更多相关主题的帖子: 34565 
2009-08-16 10:54
三断笛
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:31
帖 子:1621
专家分:1617
注 册:2007-5-24
收藏
得分:20 
ADO组件出问题了.
看看你引用的ADO版本.
重新注册ADO
2009-08-16 17:24
czqnazz00
Rank: 2
等 级:论坛游民
帖 子:38
专家分:34
注 册:2009-7-16
收藏
得分:0 
我试过对ADO多种不同引用
我分别试引用:Microsoft Activex Data Objects 2.0、2.1、2.5、2.6、2.7、2.8,都会出错。
2009-08-16 21:35
三断笛
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:31
帖 子:1621
专家分:1617
注 册:2007-5-24
收藏
得分:0 
很有可能是你装的其他软件带了ADO组件,重新注册系统的ado组件.
2009-08-16 21:49
czqnazz00
Rank: 2
等 级:论坛游民
帖 子:38
专家分:34
注 册:2009-7-16
收藏
得分:0 
怎么重新注册系统的ado组件
怎么重新注册系统的ado组件?
2009-08-16 22:04
czqnazz00
Rank: 2
等 级:论坛游民
帖 子:38
专家分:34
注 册:2009-7-16
收藏
得分:0 
怎么重新注册系统的ado组件
顶一下,怎么重新注册系统的ado组件。三断笛兄请给指点。
2009-08-16 22:40
ycbbg
Rank: 1
来 自:江西
等 级:新手上路
帖 子:99
专家分:0
注 册:2007-11-26
收藏
得分:0 
你把cnn定义成公共变量(public)试

http://www.
2009-08-17 11:05
czqnazz00
Rank: 2
等 级:论坛游民
帖 子:38
专家分:34
注 册:2009-7-16
收藏
得分:0 
问题已解决
正如三断笛兄所言,重新引用ADO即可。具体做法:“工程/引用”,打开“引用”对话框,选择“浏览”,沿着路径:c:\program Files\common Files\system\ado,选择msado15.dll打开。再次谢谢三断笛!
2009-08-17 13:53
快速回复:用ADO对象加载mdb数据库出错
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.020569 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved