我现在想把IMAGE控件中的内容保存到ACCESS数据库中,各位有什么好主意?

解决方案 »

  1.   

    用流
    把IMAGE里面的东东读到流中,然后在保存到库里面去
      

  2.   

    var
      mp:TBitmap;
      mstream : TMemoryStream;
    begin
         mstream:=TMemoryStream.Create; 
         ToolbarImages.GetBitmap(1,mp)
         mp.SaveToStream(mstream);
         mstream.Position:=0;
         TBLobField(d1.fieldbyname('MailText')).LoadFromStream(mstream);//流保存到子度
         d1.UpdateBatch
    end;
      

  3.   

    最后忘了,还要 释放流 mstream.Clear;
      

  4.   

    可以用流的方式也可以用那个DBIMAGE.不过建义用流方式虽然麻烦一点...
    这是一个完整的例子(转贴,忘记原著名字)
    用adoquery,读写数据库的图片
    unit Unit1;interfaceuses
      Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,jpeg,
      ExtDlgs, Db, DBTables, StdCtrls, ExtCtrls, ADODB;type
      TForm1 = class(TForm)
        Button1: TButton;
        OpenPictureDialog1: TOpenPictureDialog;
        Button2: TButton;
        Image1: TImage;
        ADOQuery1: TADOQuery;
        ADOQuery2: TADOQuery;
        Edit1: TEdit;
        procedure Button1Click(Sender: TObject);
        procedure Button2Click(Sender: TObject);
      private
        { Private declarations }
      public
        { Public declarations }
        filename:string;
        procedure SetPicture(pos:string;TempQuery:TADOQuery);     /////往数据库中插入图片
        procedure GetPicture(pos:string;TempQuery:TADOQuery);      ////得到图片
      end;var
      Form1: TForm1;implementation{$R *.DFM}{ TForm1 }procedure TForm1.GetPicture(pos:string;TempQuery: TADOQuery);
    var
      MS_JpegStream:TMemoryStream;
    begin
      try
        MS_JpegStream:=TMemoryStream.Create;
        with tempQuery do
          begin
            close;
            sql.clear;
            //修改这个语句
            sql.Add('select picture from table where no=:pos');
            Parameters.ParamByName('pos').value:=pos;
            Open;
          end;
        if tempquery.FieldByName('image').isnull then
          begin
            image1.Picture.Graphic:=nil;
          end
        else
          begin
             (tempQuery.FieldByName('image') as tblobfield).savetostream(MS_JpegStream);
             image1.Picture.Graphic:=nil;
             image1.Picture.Graphic:=TJpegImage.Create;
             MS_JpegStream.Position:=0;
             image1.Picture.Graphic.LoadFromStream(MS_JpegStream);
          end;  finally
        MS_JpegStream.Free;
      end;end;procedure TForm1.SetPicture(pos:string; TempQuery: TADOQuery);
    var
      MS_JpegStream:TMemoryStream;
      M_BitMap:TBitMap;
      M_Jpeg:TJpegImage;
    begin
      try
        MS_JpegStream:=TMemoryStream.Create;
        M_BitMap:=TBitMap.Create;
        M_Jpeg:=TJpegImage.Create;
        if extractfileext(filename)='.bmp' then
          begin
            M_BitMap.LoadFromFile(filename);
            M_Jpeg.Compress;
            M_Jpeg.Assign(M_BitMap);
          end
        else if extractfileext(filename)='.jpg' then
          begin
            M_Jpeg.LoadFromFile(filename);
          end;
        M_Jpeg.SaveToStream(MS_JpegStream);
        with tempQuery do
          begin
            close;
            sql.clear;
    //修改这个语句
            sql.Add('insert into table (no,IMage) values (:pos,:image)');
            Parameters.ParamByName('pos').Value:=pos;
            Parameters.ParamByName('image').LoadFromStream(MS_JpegStream,ftblob);        ExecSQL;
          end;
      finally
        MS_JpegStream.Free;
        M_BitMap.Free;
        M_Jpeg.Free;
      end;
    end;procedure TForm1.Button1Click(Sender: TObject);//打开图片并写入数据库
    begin
      if openpicturedialog1.Execute then
      begin
       filename:=openpicturedialog1.FileName;
       SetPicture(edit1.text,ADOQuery1);
      end
    end;procedure TForm1.Button2Click(Sender: TObject);//显示图片
    begin
      getpicture(edit1.text,ADOQuery2);
    end;end.
      

  5.   

    放在数据库中会使数据库快速增大,放在数据库外,只在数据库中保存图片路径。
    我这里有例子:http://www.web1688.com
      

  6.   

    放在数据库中会使数据库快速增大,放在数据库外,只在数据库中保存图片路径。
    我这里有例子:http://www.web1688.com