VB/VBA中实现数据库中的文件存取

' VB/VBA中实现数据库中的文件存取

' 示例数据库为ACCESS数据库,用SQL数据库的话,只需要改连接字符串
'
'
*************************************************************************
'
**
'
** 使用 ADODB.Stream 保存/读取文件到数据库
'
** 引用 Microsoft ActiveX Data Objects 2.5 Library 及以上版本
'
**
'
** ----- 数据库连接字符串模板 ---------------------------------------
'
** ACCESS数据库
'
** iConcStr = "Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=False" & _
'
**     ";Data Source=数据库名"
'
**
'
** SQL数据库
'
** iConcStr = "Provider=SQLOLEDB.1;Persist Security Info=True;" & _
'
**     "User ID=用户名;Password=密码;Initial Catalog=数据库名;Data Source=SQL服务器名"
'
**
'
*************************************************************************
'
'
保存文件到数据库中
Sub  s_SaveFile()
    
Dim  iStm  As  ADODB.Stream
    
Dim  iRe  As  ADODB.Recordset
    
Dim  iConcStr  As   String
    
    
' ACCESS数据库的连接字符串
    iConcStr  =   " Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=False "   &  _
        
" ;Data Source=F:My Documents客户资料1.mdb "
    
    
' SQL数据库的连接字符串
    iConcStr  =   " Provider=SQLOLEDB.1;Persist Security Info=True; "   &  _
        
" User ID=用户名;Password=密码;Initial Catalog=数据库名;Data Source=SQL服务器名 "
    
' 读取文件到内容
     Set  iStm  =   New  ADODB.Stream
    
With  iStm
        .Type 
=  adTypeBinary     ' 二进制模式,如果是用text/ntext字段保存纯文本数据,则改用 adTypeText
        .Open
        .LoadFromFile 
" c: est.doc "
    
End   With
    
    
' 打开保存文件的表
     Set  iRe  =   New  ADODB.Recordset
    
With  iRe
        .Open 
" " , iConc, adOpenKeyset, adLockOptimistic
        .AddNew         
' 新增一条记录
        .Fields( " 保存文件内容的字段 " =  iStm.Read
        .Update
    
End   With
    
    
' 完成后关闭对象
    iRe.Close
    iStm.Close
End Sub

' 从数据库中读取数据,保存成文件
Sub  s_ReadFile()
    
Dim  iStm  As  ADODB.Stream
    
Dim  iRe  As  ADODB.Recordset
    
Dim  iConc  As   String
    
    
' 数据库连接字符串
    iConc  =   " Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=False "   &  _
        
" ;Data Source=/xzc$Inetpubzjzjzj.mdb "
    
    
' 打开表
     Set  iRe  =   New  ADODB.Recordset
    iRe.Open 
" tb_img " , iConc, adOpenKeyset, adLockReadOnly
    iRe.Filter 
=   " id=64 "

    
if  iRe( " img " ).ActualSize > 0   Then

        
' 保存到文件
         Set  iStm  =   New  ADODB.Stream
        
With  iStm
            .Mode 
=  adModeReadWrite
            .Type 
=  adTypeBinary  ' 二进制模式,如果是用text/ntext字段保存纯文本数据,则改用 adTypeText
            .Open
            .Write iRe(
" img " )
            .SaveToFile 
" c: est.doc "
        
End   With
    
        
' 关闭对象
        iStm.Close
    
End   If

    iRe.Close
End Sub
 
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

红火吖

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值