'代码出处:http://zhidao.baidu.com/question/145401203.html
'在工程中引用Microsoft ActiveX Data Object 2.6或者更高的版本
Dim db As New ADODB.Connection '声明数据库对像
Dim rs As New ADODB.Recordset '声明表对像
Dim mstream As ADODB.Stream '声明流对像(好像也叫二进制对像)
Private Sub 登录数据库_Click() '打开数据库
On Error GoTo ErrHandle '错误处理
db.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\Data.mdb" '无密码访问
'db.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\Data2.mdb;Jet OLEDB:database password=123456" '有密码访问123456为数据库密码
rs.Open "Select * From 学生名单 ", db, 1, 3
'rs.Open "Select * From 学生名单 ", db, 1, A 'A=1表示读取数据;A=3表示新增、修改或删除数据
ErrHandle: '错误处理
Select Case Err.Number
Case -2147217843
MsgBox "数据库密码错误,请从新输入!", vbInformation, "您好"
End Select
If rs.State = adStateOpen Then
'AdStateClosed指rs对象是关闭的
'AdStateOpen指rs对象是打开的
'AdStateConnectingrs指rs对象正在连接
'AdStateExecutingrs指rs对象正在执行命令
'AdStateFetchingrs指rs对象的行正在被读取
MsgBox "数据库已成功打开!", vbInformation, "您好"
End If
End Sub
Private Sub Form_Unload(Cancel As Integer) '关闭数据库
rs.Close '关闭表
db.Close '关闭数据库
End Sub
Private Sub Command2_Click() '指向下一条记录
If rs.EOF = True Then '如果是最后一条记录(true为是,False为不是)
MsgBox "这已是最后一条记录!", vbInformation, "您好"
Else '如果不是最后一条记录
rs.MoveNext '指向下一条
End If
End Sub
Private Sub Command3_Click() '指向上一条记录
If rs.BOF = True Then '如果是最前一条记录(true为是,False为不是)
MsgBox "这已是最前一条记录!", vbInformation, "您好"
Else '如果不是最前一条记录
rs.MovePrevious '指向上一条
End If
End Sub
Private Sub Command4_Click() '指向第一条记录
rs.MoveFirst '指向第一条
End Sub
Private Sub Command5_Click() '指向最后一条记录
rs.MoveLast '指向最后一条
End Sub
Private Sub Command6_Click() '向下移动1行
rs.Move 1 '向下移动1行
End Sub
Private Sub Command7_Click() '添加记录
rs.AddNew
rs.Fields(0) = "666" '对应编号列
rs.Fields(1) = "大哥" '对应姓名列
rs.Fields(2) = "23" '对应年龄列
rs.Update
End Sub
Private Sub Command8_Click() '更新记录(更新的是当前行)
rs("姓名") = "小弟" '对应姓名列
rs("年龄") = "23" '对应年龄列
rs.Update
End Sub
Private Sub Command9_Click() '删除记录(删除的是当前行)
rs.Delete (0)
End Sub
Private Sub Command10_Click() '查找记录
rs.Find "编号='168'" '168为查找条件
If rs.EOF = False Then
MsgBox "已找到符合条件记录!且已移动到该条记录下!", vbInformation, "您好"
Else
MsgBox "对不起,啥也没找到!", vbInformation, "您好"
End If
End Sub
Private Sub Command12_Click() '更新文件(更新的是当前行)
Set mstream = New ADODB.Stream
mstream.Type = adTypeBinary
mstream.Open
mstream.LoadFromFile "c:\美女图片.jpg"
rs.Fields("二进制").Value = mstream.Read '对应二进制列
rs.Update
End Sub
Private Sub Command13_Click() '添加文件(添加一行新文件)
Set mstream = New ADODB.Stream
mstream.Type = adTypeBinary
mstream.Open
mstream.LoadFromFile "c:\1.exe"
rs.AddNew
rs.Fields(0) = "88" '对应编号列
rs.Fields(1) = "小" '对应姓名列
rs.Fields(2) = "20" '对应年龄列
rs.Fields("二进制").Value = mstream.Read '对应二进制列
rs.Update
End Sub
Private Sub Command14_Click() '导出文件(导出当前行的文件)
Set mstream = New ADODB.Stream
mstream.Type = adTypeBinary
mstream.Open
mstream.Position = 0
mstream.Write rs.Fields("二进制").Value '对应二进制列
mstream.SaveToFile "c:\2.exe", adSaveCreateOverWrite
End Sub
Private Sub Command15_Click() '删除文件(删除当前行的文件)
rs("二进制") = ""
rs.Update
End Sub
Private Sub Command1_Click() '显示记录
'代码出处:http://blog.sina.com.cn/s/blog_6d5459990100yr2r.html
Text1.Text = rs.Fields("编号") '将编号这个字段第一行数据(默认是第一行数据)赋值给Text1
Text2.Text = rs.Fields("姓名") '将姓名这个字段第一行数据(默认是第一行数据)赋值给Text2
Text3.Text = rs.Fields("年龄") '将年龄这个字段第一行数据(默认是第一行数据)赋值给Text3
Text4.Text = rs.Fields.Count '数据表总字段数(也就是数据表总列数)
Text5.Text = rs.RecordCount '数据表记录总数(也就是数据表总行数)
Text6.Text = rs(0).Name '第1个字段的名称(也就是数据表第1列列头的文字)
Text7.Text = rs(0) '第1个字段的数据(也就是数据表第1列列头下面的第一行文字)
Text8.Text = rs("姓名") '指定字段数据(和rs.Fields类似)
End Sub
'==============================修改数据库密码(建议每次退出程序时执行一次)==============================
'工程-引用Microsoft Jet and Replication Objects Library 2.6 Library
Private Sub Command11_Click()
Dim miJRO As JRO.JetEngine
Set miJRO = New JRO.JetEngine
miJRO.CompactDatabase "Provider=Microsoft.Jet.OLEDB.4.0; " & "Data Source=" & "C:\Data.mdb;" & "Jet OLEDB:Database Password=123", _
"Provider=Microsoft.Jet.OLEDB.4.0; " & "Data Source=" & "C:\Data0.mdb;" & "Jet OLEDB:Database Password=abc" '123为修改前的密码 abc为修改后的密码
End Sub
'======================================================================================================