向高手求救﹕從SQL Server中讀取jpg圖片(100分)

  • 主题发起人 主题发起人 liyu
  • 开始时间 开始时间
L

liyu

Unregistered / Unconfirmed
GUEST, unregistred user!
本人使用Delphi/Mts/ADO/Sql Server開發三層分布式數據庫應用程式﹐在SQL Server中存取Blob
字段時出現錯誤﹐過去曾利用BDE數據庫引擎從ORACLE中利用TImage控件讀出來了﹐但現在
轉成三層結構和使用ADO/SQL SERVER 時卻出現了錯誤﹐請各位大俠多幫忙!
 
错误信息。最好把出错的那部分代码也写上。
 
是用的TADOBlobStream吗?
 
用TBlobField试用一下
 
Delphi提供了数据访问(DataAccess)和数据控制(
DataControls)的可视化控件,能够方便快捷地产生具有
良好界面且功能强大的数据库应用程序。对于涉及图像数
据(含Graphic字段)的数据库应用程序,如人事管理信
息系统等,图像数据的存取技术是一个关键。然而,有关D
elphi下图象的存取,特别是图像的保存方面的技术各种
资料上很少提及。下面,笔者结合一个简单的例子来说明

   一、图像数据的保存
  1.创建一个含有Graphic字段的数据库列表。
  在WindowsISQ(或Databasedesktop)下createdatabasemydb.gdb
  createtablemyfrieds
  (namevarchar(15)notnull,telephonevarchar(
12),addressvarchar(30),zipvarchar(8),pictu
revarchar(15),imageblob);
  其中,picture字段用于保存图像的名称(包括路径
),image(Graphic字符)则用于存储图像,其数据类型
为“blob”。
  2.建立窗体(如图1所示),设置窗体中各控件的属
性。
  
  该窗体的主要功能是将某人信息进行编辑和保存。需
要注意的图像保存所用的图像框必须用TImage而不能用TD
BIm?age,编辑框宜用Tedit而不宜用TDBEdit,这一点与
图像的读取恰好相反。
  其中,各主要控件的属性设置如下:
  Datasource1.Dataset:Κtable1;
  Datasource1.Dataset:Κtable1;
  Table1.Databasename:Κmydb.gdb;
  Table1.Tablename:Κmyfriends;
  Table1.active:Κtrue;
  其他诸如Caption之类的属性设置不再叙述。
  3.数据处理程序的建立。
  (1)图像( .bmp文件)打开的处理。
  procedureTForm1.pictopenbtnClick(Sender:TObject);
  begin
opendialog1.execute;
  image1.picture.loadfromfile
  (opendialog1.filename);
  end;
  end;
  (2)图像保存的处理。
  图像保存的处理程序完成把在窗体1所编辑的信息包
括图像保存到相应的数据库中,其关键是要定义一个Graph
ic类型的变量且该变量要用assing()函数传递到相应数
据库中保存。具体程序如下:
  procedureTform1.Savebtnclick(sender:TObject);
  vargraphic1:TGraphic;
  begin
graphic1:ΚTGraphic.Create;
  graphic1.loadfromfile(opendialog1.filename);
  table1.insert;
  table1.fieldbyname(′name′).asstring:Κedit1.text;
  table1.fieldbyname(′telephon′).asstring:Κedit2.text;

  table1.fieldbyname(′address′).asfloat:Κ(edit3.text);
  table1.fieldbyname(′zip′).asfloat:Κ(edit4.text);
  table1.fields[4].assign(graphic1);
  table1.post;
  graphic1.free;
  end;
   二、图像数据的读取
  在数据库数据(包括Graphic字段的数据)的读取和
浏览方面,Delphi这一具有强大代码自动生成功能的面向
对象的开发工具的优越性得到淋漓尽致的体现。毫不夸张
地说,不需要一条语句即可完成这一功能!
  建立窗体(如下图所示),设置各控件的属性。
  图中Table1和Datasource1的属性的设置与数据的保
存部分(图1)相同,所不同的是数据库数据的读取时用TD
BEdit和TD?BImage控件而不用TEdit和TImage。控件TDBE
dit和TDBImage只要将datafield属性设置为其相对应的域
;TDBNavigator的datasouce属性设置为datasource1即可
 
關于這個問題﹐我已解決﹐使用TClientStream便可﹐謝謝各位的參與﹗
隨便問一句﹐如何將分數還給我?
 
呜呜,我也是提出问题后自己解决的。回答的都不对,但分--泼出去的水,收不回来了。
呜呜.
 
嘿嘿,所以要少提问题
 
收不会的吧!
 
多人接受答案了。
 
to liyu:
如何解决的,麻烦你把代码发给我trackboy@163.com,十万火急!!!
 
后退
顶部