我用的代码是:
  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
 

解决方案 »

  1.   

    经过测试'http://support.microsoft.com/default.aspx?scid=kb;EN-US;258038'*************************************************************************
    '**
    '** 使用 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
      

  2.   

    http://community.csdn.net/Expert/topic/3124/3124855.xml?temp=.1925165
      

  3.   

    dsn中用Microsoft OLE DB provider for Drivers进行连接,是不是与它有关系呢?各位大侠,帮帮我呀.
      

  4.   

    MYSQL数据库,将字段类型设置成LONGBLOB类型!
    代码如下: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经过测试!!!
      

  5.   

    先谢cuizm(射天狼),但我还是不能写入(数据库中相应字段无任何值).您帮我看看代码 
    返回的错误是:多步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
      

  6.   

    我新建了一个数据库之后也遇到了你说的这个错误,我用PB的数据库窗口向表中插入一条新记录(照片字段必须插入值,否则不行),然后再用VB添加就没问题了,可能是MYSQL的原因,或者需要初始化什么东西,不得其法!我再想想办法!!