把EXE文件存入到表的字段中,再从表中读出存到硬盘中的代码
'假定表:tbl1,字段:F1
Option Compare Database
Option Explicit
Public Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (Destination As Any, Source As Any, ByVal Length As Long)
Public Function ReadFile(ByVal strFile As String) As Boolean
On Error GoTo Doerr
Dim lngFileNum As Long
Dim varFile As Variant
Dim rst As New ADODB.Recordset
Dim strSql As String
Dim str As String
Dim lngLen As Long
Dim bytFile() As Byte
Dim lngI As Long, lngMax As Long
lngFileNum = FreeFile
Open strFile For Binary As lngFileNum
lngLen = LOF(lngFileNum) / 2
ReDim bytFile(lngLen * 2)
Do Until EOF(lngFileNum)
Get lngFileNum, , bytFile(lngI)
lngI = lngI + 1
Loop
lngMax = lngI
str = Space(lngLen)
CopyMemory ByVal StrPtr(str), bytFile(0), lngLen * 2
strSql = "tbl1"
rst.Open strSql, CurrentProject.Connection, adOpenKeyset, adLockOptimistic, adCmdTable
If rst.EOF Then rst.AddNew
rst.Fields(0).AppendChunk str
Debug.Print rst.Fields(0).ActualSize
rst.Update
rst.Close
Close lngFileNum
Complete:
GoTo Quit
Doerr:
Errexit:
Debug.Print Err.Description
Quit:
End Function
Public Function writeFile(ByVal strFile As String) As Boolean
On Error GoTo Doerr
Dim lngFileNum As Long
Dim rst As New ADODB.Recordset
Dim strSql As String
Dim str As String
Dim lngLen As Long
Dim bytFile() As Byte
Dim lngI As Long
Set rst = New ADODB.Recordset
strSql = "tbl1"
rst.Open strSql, CurrentProject.Connection, adOpenStatic, adLockReadOnly, adCmdTable
lngLen = rst.Fields(0).ActualSize / 2
str = rst.Fields(0).GetChunk(lngLen * 2)
ReDim bytFile(lngLen * 2)
rst.Close
CopyMemory bytFile(0), ByVal StrPtr(str), lngLen * 2
lngFileNum = FreeFile
Open strFile For Binary As lngFileNum
For lngI = 0 To lngLen * 2
Put lngFileNum, , bytFile(lngI)
Next
Close lngFileNum
Complete:
GoTo Quit
Doerr:
Errexit:
Debug.Print Err.Description
Quit:
End Function
(责任编辑:admin)
- ·API函数详细解释
- ·Access从剪切版里复制和粘贴数据
- ·Access利用api实现打开/关闭光驱
- ·应用程序开机自动启动(注册表操作技巧
- ·Access VBA 判断网络是否连通的多种办
- ·什么是ADP,了解ADP的优缺点
- ·优秀产品大全--通用票据打印软件(新)
- ·[技巧分享]多条Shell语句执行导致判断
- ·在access中可以调用API函数GetFileInfo
- ·Access API集中营--增加临时使用的字体
- ·API ShellExecute 功能说明及应用示例
- ·在VB中使用API函数(什么是API? )
- ·API实现完美的图片出现效果(转)
- ·API 设置调整系统当前时间
- ·如何检测以及设置键盘状态
- ·不关闭当前数据库COPY当前数据库