图像与数据库相关的问题 我想在数据库中sql sever 2000 中的一个表man(name,id,photo)其中photo是image 类型,我想往表中加入一个图片,可经是bmp 与jpeg类型,请问代码应该是如何啊?以及要用到什么控件啊?同时我想把它读出来在表中控件image 中显示,代码又是如何啊?希望各位高手可以帮小弟一把 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 我找的一些代码procedure TForm1.Button1Click(Sender: TObject);begin adotable1.Append ;end;procedure TForm1.Button3Click(Sender: TObject);begin opd1.Execute ; if opd1.FileName <> '' then begin form2.Image1.Picture.LoadFromFile(opd1.FileName); form2.show; end;end;procedure TForm1.DBGrid1DblClick(Sender: TObject);varms:TStringStream;Jpg:TJpegImage;begin //显示 ms:=TstringStream.Create(''); Jpg:=TJpegImage.Create; TBlobField(ADOTable1.FieldByName('zp')).SaveToStream(ms); jpg.LoadFromStream(ms); ms.Position :=0; Jpg.LoadFromStream(ms);// Form2.Image1.Picture.Bitmap.LoadFromStream(ms); //调用bmp图像的方法 form2.Image1.Picture.Assign(jpg); {如果JpegImage是从一个文件中load的话(loadfromstream),图像就可以正常显示, 而从数据库字段中读到流里,JpegImage再从这个流里load,就不行, 会出现错误JPEG error #41。} Form2.Show; form2.Position :=poScreenCenter;end;procedure TForm1.Button2Click(Sender: TObject);varmsmem:TmemoryStream;jpg:TJpegImage;begin //保存 msmem:=TmemoryStream.Create; Jpg:=TjpegImage.Create; jpg.Assign(form2.Image1.Picture.Graphic); jpg.SaveToStream(msmem) ; // 1// form2.Image1.Picture.Bitmap.SaveToStream(msmem); // 保存bmp图像的方法 msmem.Position :=0; adotable1.Edit ; TBlobField(ADOTable1.FieldByName('zp')).LoadFromStream(msmem); ADOTable1.Post ; Msmem.Free ; jpg.Free;end;procedure TForm1.FormCreate(Sender: TObject);begin adoconnection1.Connected :=true; adotable1.Active :=true;end;procedure TForm1.FormDestroy(Sender: TObject);begin adoconnection1.Connected :=false;end; DBGRIDEH如何添加自定义的函数 帮忙优化代码,找错,分数会追加 SQL数据库还原 stringGrid如果涉及到按shift进行多行删除记录的情况,怎么实现? fastreport报表如何能自动调整页数。 一个关于文本框的问题 一段我怎么也找不出错误的程序!谁能找出来? 对datetimepicker的查询操作 如何用Delphi对两个数据库中的表进行操作 有谁知道InforPower3000的SN 高分求教::用ADOConnection1.Execute从txt文件导入数据时如何更改数据类型? 不打开某个窗体不连接到数据库,如何设置?
begin
adotable1.Append ;
end;procedure TForm1.Button3Click(Sender: TObject);
begin
opd1.Execute ;
if opd1.FileName <> '' then
begin
form2.Image1.Picture.LoadFromFile(opd1.FileName);
form2.show;
end;
end;procedure TForm1.DBGrid1DblClick(Sender: TObject);
var
ms:TStringStream;
Jpg:TJpegImage;
begin //显示
ms:=TstringStream.Create('');
Jpg:=TJpegImage.Create;
TBlobField(ADOTable1.FieldByName('zp')).SaveToStream(ms);
jpg.LoadFromStream(ms);
ms.Position :=0;
Jpg.LoadFromStream(ms);
// Form2.Image1.Picture.Bitmap.LoadFromStream(ms); //调用bmp图像的方法
form2.Image1.Picture.Assign(jpg); {如果JpegImage是从一个文件中load的话(loadfromstream),图像就可以正常显示,
而从数据库字段中读到流里,JpegImage再从这个流里load,就不行,
会出现错误JPEG error #41。}
Form2.Show;
form2.Position :=poScreenCenter;end;procedure TForm1.Button2Click(Sender: TObject);
var
msmem:TmemoryStream;
jpg:TJpegImage;
begin //保存
msmem:=TmemoryStream.Create;
Jpg:=TjpegImage.Create;
jpg.Assign(form2.Image1.Picture.Graphic);
jpg.SaveToStream(msmem) ; // 1
// form2.Image1.Picture.Bitmap.SaveToStream(msmem); // 保存bmp图像的方法
msmem.Position :=0;
adotable1.Edit ;
TBlobField(ADOTable1.FieldByName('zp')).LoadFromStream(msmem);
ADOTable1.Post ;
Msmem.Free ;
jpg.Free;
end;procedure TForm1.FormCreate(Sender: TObject);
begin
adoconnection1.Connected :=true;
adotable1.Active :=true;
end;procedure TForm1.FormDestroy(Sender: TObject);
begin
adoconnection1.Connected :=false;
end;