我用的代码是:
Private Sub Command8_Click()
Dim stmCon As New Stream
Dim adors As ADODB.Recordset
Dim MySql As String
Dim MsgAbout As String
MsgAbout = "错误!!"
CommonDialog1.DialogTitle = "图片资料"
CommonDialog1.Filter = "图片文件(*.JPG)|*.JPG|图片文件(*.bmp)|*.bmp|所有文件(*.*)|*.*"
CommonDialog1.InitDir = "D:"
CommonDialog1.Action = 1
Image1.Picture = LoadPicture(CommonDialog1.filename)
stmCon.Type = adTypeBinary
stmCon.Open
stmCon.LoadFromFile CommonDialog1.filename
MySql = "select * from sick"
Set adors = ExecuteSQL(MySql, MsgAbout)
adors.Fields("photo").Value = stmCon.Read
adors.Update stmCon.Close
Set stmCon = Nothing
End Sub
返回的错误是:
实时错误'-2147217887(80040e21)':多步OLE DB操作产生错误,请检查每个OLE DB状态值.没有工作被完成.
是什么原因啊?怎么检查OLE DB的状态值啊?
出现错误的是此行:adors.Fields("photo").Value = stmCon.Read
Private Sub Command8_Click()
Dim stmCon As New Stream
Dim adors As ADODB.Recordset
Dim MySql As String
Dim MsgAbout As String
MsgAbout = "错误!!"
CommonDialog1.DialogTitle = "图片资料"
CommonDialog1.Filter = "图片文件(*.JPG)|*.JPG|图片文件(*.bmp)|*.bmp|所有文件(*.*)|*.*"
CommonDialog1.InitDir = "D:"
CommonDialog1.Action = 1
Image1.Picture = LoadPicture(CommonDialog1.filename)
stmCon.Type = adTypeBinary
stmCon.Open
stmCon.LoadFromFile CommonDialog1.filename
MySql = "select * from sick"
Set adors = ExecuteSQL(MySql, MsgAbout)
adors.Fields("photo").Value = stmCon.Read
adors.Update stmCon.Close
Set stmCon = Nothing
End Sub
返回的错误是:
实时错误'-2147217887(80040e21)':多步OLE DB操作产生错误,请检查每个OLE DB状态值.没有工作被完成.
是什么原因啊?怎么检查OLE DB的状态值啊?
出现错误的是此行:adors.Fields("photo").Value = stmCon.Read
解决方案 »
- vb_如何将数据写入ACCESS ?
- 曲求牛人教我VB
- GetObject(, "Excel.Application")遇到的问题(在线)
- 一个不太清楚的问题:
- 请问:在程序中,如何将一个文件夹及其中的文件设置为只读属性?
- MSHFlexGrid的问题
- 急,请教各位高手,一个涉及VB,Excel和InstallShield的问题。
- 请教:若我想在我的VB应用程序中直接调用如记事本或UEDIT,并且直接打开现有的文件, 该怎么做?
- 如何在vb中使用source safe,如何安装souce safe 的客户端?(立刻给分)
- vb里如何读取文件的创建更新时间等信息
- 读取快捷方式属性。没则了! yinweihong(yige) 请进!
- 新手提问---对数据库添加图片时出现错误,请各位江湖好汉帮忙解决[在线等]
'**
'** 使用 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
'数据库连接字符串
iConcStr = "Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=False" & _
";Data Source=F:\csdn_vb\database\保存图片\img.mdb"
Dim iConc As ADODB.Connection
Set iConc = New ADODB.Connection
iConc.Open iConcStr
'读取文件到内容
Set iStm = New ADODB.Stream
With iStm
.Type = adTypeBinary '二进制模式
.Open
.LoadFromFile App.Path + "\com.doc"
End With
'打开保存文件的表
Set iRe = New ADODB.Recordset
With iRe
.Open "select * from img", iConc, 1, 3
.AddNew '新增一条记录
.Fields("photo") = iStm.Read
.Update
End With
'完成后关闭对象
iRe.Close
iStm.Close
End SubSub 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=F:\csdn_vb\database\保存图片\img.mdb"
'打开表
Set iRe = New ADODB.Recordset
iRe.Open "img", iConc, adOpenKeyset, adLockReadOnly
iRe.Filter = "id=3" '比如单击datagrid后找到id=3的纪录
'保存到文件
Set iStm = New ADODB.Stream
With iStm
.Mode = adModeReadWrite
.Type = adTypeBinary
.Open
.Write iRe("photo")
.SaveToFile "c:\com.doc"
End With
OLE1.SourceDoc = "c:\\com.doc"
OLE1.Action = 1 'use the old action method
OLE1.SizeMode = vbOLESizeAuttoSize '调节对象大小使其正好充满OLE容器控件 'Picture1.Picture = LoadPicture("c:\tesd.bmp")
'关闭对象
iRe.Close
iStm.Close
End SubPrivate Sub Command1_Click()
Call s_ReadFile
End SubPrivate Sub Command2_Click()
Call s_SaveFile
End Sub
代码如下:Option Explicit'工程->引用->Microsoft ActiveX Data Object 2.6 Library (后面为版本号)
Dim cn As New ADODB.Connection, rs As New ADODB.Recordset'保存
Private Sub Command1_Click()
Dim stmCon As New Stream
stmCon.Type = adTypeBinary
stmCon.Open
stmCon.LoadFromFile "C:\aa.JPG"
If rs.State = adStateOpen Then rs.Close
rs.Open "SELECT * FROM TABLENAME", cn, adOpenDynamic, adLockOptimistic
rs.AddNew
rs!ID = "12"
rs!Name = "11"
rs.Fields("PHOTO").Value = stmCon.Read
rs.Update
stmCon.Close
Set stmCon = Nothing
End Sub'打开
Private Sub Command2_Click()
Dim stmCon As New Stream
If rs.State = adStateOpen Then rs.Close
rs.Open "SELECT * FROM TABLENAME", cn, adOpenForwardOnly, adLockReadOnly
If Not rs.EOF Then
stmCon.Type = adTypeBinary
stmCon.Open
stmCon.Write (rs.Fields("PHOTO").Value)
stmCon.SaveToFile "C:\aa.bmp", adSaveCreateOverWrite
End If Image1.Picture = LoadPicture("C:\aa.bmp")
End SubPrivate Sub Form_Load()
On Error GoTo Errhandle
'cn.ConnectionString = "Driver={SQL Server};SERVER=DataServer;DATABASE=zxzx;UID=information;PWD=information*&#"
'cn.ConnectionString = "DBQ=D:\My Documents\db2.mdb;DefaultDir=" & _
App.Path & ";Driver={Microsoft Access Driver (*.mdb)};" & _
"DriverId=25;FIL=MS Access;ImplicitCommitSync=Yes;" & _
"MaxBufferSize=512;MaxScanRows=8;PageTimeout=5;SafeTransactions=0;" & _
"Threads=3;UID=ADMIN;UserCommitSync=Yes;PWD=;"
cn.ConnectionString = "Driver={MySQL};Option=262144;port=1024;stmt=;Server=192.168.2.126;DataBase=mysql;User=root;Password="
'cn.ConnectionString = "DSN=oa;UID=root;PWD="
cn.Open
Exit Sub
Errhandle:
MsgBox Err.Description, vbExclamation
End SubPrivate Sub Form_QueryUnload(Cancel As Integer, UnloadMode As Integer)
On Error Resume Next
rs.Close
Set rs = Nothing
cn.Close
Set cn = Nothing
End Sub经过测试!!!
返回的错误是:多步OLE DB操作产生错误,请检查每个OLE DB状态值.没有工作被完成.
Dim cn As New ADODB.Connection
Dim adors As New ADODB.RecordsetPrivate Sub Command1_Click()
On Error GoTo Errhandle
Dim stmCon As New Stream
CommonDialog1.DialogTitle = "图片资料"
CommonDialog1.Filter = "图片文件(*.JPG;*.bmp;*.gif)|*.JPG;*.bmp;*.gif|所有文件(*.*)|*.*"
CommonDialog1.InitDir = "D:\q\zx"
CommonDialog1.Action = 1
Image1.Picture = LoadPicture(CommonDialog1.FileName)
stmCon.Type = adTypeBinary
stmCon.Open
stmCon.LoadFromFile CommonDialog1.FileName
If adors.State = adStateOpen Then adors.Close
adors.Open "SELECT * FROM admin where name='guest'", cn, adOpenDynamic, adLockOptimistic
adors.Fields("photo").Value = stmCon.Read
adors.Update
stmCon.Close
Set stmCon = Nothing
Errhandle:
MsgBox Err.Description, vbExclamation
End SubPrivate Sub Command2_Click()
Unload Me
End SubPrivate Sub Form_Load()
cn.ConnectionString = "DSN=cqh;UID=root;PWD="
cn.Open
End Sub