VBA EXCEL 实现图片保存到ACCESS数据库(OLE对象)

在网上看了很多教程,VBA怎么把图片通过ACCESS数据库的OLE对象传到数据库。结果全是其他语言写的。我今天用VBA 实现一下以下功能:代码前需引用  Microsoft Activex Data Objects x.x 库

1,把图片保存到ACCESS(通过OLE对象)

Sub 保存图片到ACCESS数据库()
'头像那列数据库类型为OLE对象
Dim con As New ADODB.Connection '
Dim command As New ADODB.command

With con
.Provider = "microsoft.ace.oledb.12.0"
.ConnectionString = "d:\cs.accdb"
.Open
End With
Dim b() As Byte
Open "d:\b.jpg" For Binary As #1
 x = LOF(1)
 ReDim i(1 To x)
Get #1, , b
Close #1
command.ActiveConnection = con
command.CommandType = adCmdText
command.CommandText = "insert into 表1(头像) values(@头像)"
command.Parameters.Append command.CreateParameter("@头像", adBinary, , x, b)
command.Execute
con.Close
Set con = Nothing
End Sub
 

2,把ACCESS数据库中的图片保存到本地硬盘。

Sub 保存图片到本地()

Dim con As New ADODB.Connection
Dim rs As New ADODB.Recordset
Dim b() As Byte
With con
.Provider = "microsoft.ace.oledb.12.0"
.ConnectionString = "d:\cs.accdb"
.Open
End With
Set rs = con.Execute("select * from 表1 where id=7")
b = rs.Fields("头像")
Open "d:\头像.jpg" For Binary As #1
Put #1, , b
Close #1
con.Close
Set con = Nothing
End Sub

  • 2
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值