通行证: 用户 密码
域名空间  下载中心 社区论坛 信息公告 my小屋
联系我们
设为首页
加入收藏
热门:qq挂机,asp,php,jsp,xml
,sql,.net,编程 程序 网页图象
首页>网络编程>其他相关>正文 中国黑客群攻击美政府网站 拿到部   微软计划开放office文件格式 消除   腾讯联合八部门严厉打击挂机网站   神六载人飞行圆满成功   美国会要求nasa彻底完成空间站建   google中国研究院有望落户清华   深度分析:论雅虎中国的夭折和阿   神六可能于10月13日上午11点发射   盖茨继续当全美首富   adobe ceo痛斥微软 称其管理层从   
热 点 排 行
dll文件下载
qq挂机的n种快速方法
长白山天池怪兽再现 一分钟
腾讯qq调整升级条件 不再诱
ape歌曲的播放、转换和刻录
新开放qq免费挂级网站
qq挂级程序,qq免费挂机源程
刘亦菲 变性人、堕胎,自称
photoshop通道抠图:给秀发
免费把qq炫铃设为本机qq的
用通通通作代理在局域网上
用6位qq注意啦,免费领取6位
超级女声总决赛 现场实况(
用nero制作win98多功能启动
亲身体验!让桌面不再粗糙
推 荐 新 闻
中国黑客群攻击美政府网站
bittorrent被好莱坞招安盗
网站建设中,关键词选择技
神六载人飞行圆满成功
国庆长假上网慎防“移动杀
连环起诉google 传统媒体欲
最强秘籍 ie7最新使用技巧
神六完成总装可接航天器 外
adobe ceo痛斥微软 称其管
微软急调张亚勤回中国 千里
微软宣布重大重组方案 将划
腾讯qq 2005 beta3火热发布
腾讯扩张路线图曝光 陈天桥
腾讯拍拍网正式吹响进军c2
第五届“西湖论剑”文字实
相 关 新 闻
首页>网络编程>其他相关>正文

数据库中图像数据的存取技术


http://www.iyit.net  日期:2005-11-24 17:47:49  来源:易特网络技术  点击:
数据库应用程序开发中图像数据的存取技术

delphi提供了数据访问(dataaccess)和数据控制(datacontrols)的可视化控件,能够方便快捷地产生具有良好界面且功能强大的数据库应用程序。对于涉及图像数据(含graphic字段)的数据库应用程序,如人事管理信息系统等,图像数据的存取技术是一个关键。然而,有关delphi下图象的存取,特别是图像的保存方面的技术各种资料上很少提及。下面,笔者结合一个简单的例子来说明。

一、图像数据的保存

1.创建一个含有graphic字段的数据库列表。

在windowsisq(或databasedesktop)下create database mydb.gdb

create table myfrieds(name varchar(15) notnull,telephone varchar(12), address varchar(30),zipvarchar(8),picture varchar(15),image blob);

其中,picture字段用于保存图像的名称(包括路径),image(graphic字符)则用于存储图像,其数据类型为“blob”。

2.建立窗体(如图1所示),设置窗体中各控件的属性。

该窗体的主要功能是将某人信息进行编辑和保存。需要注意的图像保存所用的图像框必须用timage而不能用tdbimage,编辑框宜用tedit而不宜用tdbedit,这一点与图像的读取恰好相反。

其中,各主要控件的属性设置如下:

datasource1.dataset:=table1;

table1.databasename:=mydb.gdb;

table1.tablename:=myfriends;

table1.active:=true;

其他诸如caption之类的属性设置不再叙述。


3.数据处理程序的建立。

(1)图像( .bmp文件)打开的处理。

proceduretform1.pictopenbtnclick(sender:tobject);

beginopendialog1.execute;

image1.picture.loadfromfile(opendialog1.filename);

end;

(2)图像保存的处理。

图像保存的处理程序完成把在窗体1所编辑的信息包括图像保存到相应的数据库中,其关键是要定义一个graphic类型的变量且该变量要用assign()函数传递到相应数据库中保存。具体程序如下:

proceduretform1.savebtnclick(sender:tobject);

var

graphic1: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)相同,所不同的是数据库数据的读取时用tdbedit和tdbimage控件而不用tedit和timage。控件tdbedit和tdbimage只要将datafield属性设置为其相对应的域;tdbnavigator的datasouce属性设置为datasource1即可。
tre 

procedure tform1.button1click(sender: tobject);
var
sfilename:string;
function blobcont(const filename:string):string;
  begin
  with tfilestream.create(filename,fmopenread) do
   try
    setlength(result,size);
    read(pointer(result)^,size);
   finally
    free;
   end;
  end;

begin
if opendialog1.execute then
  begin
    sfilename:=opendialog1.filename;
    adodataset1.append;
    adodataset1.fieldbyname(’ff’).asstring:=blobcont(sfilename);
    adodataset1.post;
  end;
end;

procedure tform1.button2click(sender: tobject);
var
sfilename:string;
bs:tadoblobstream;
begin
bs:=tadoblobstream.create(tblobfield(adodataset1.fieldbyname(’ff’)),bmread);
try

  sfilename:=’c:ff.doc’;//换成图片格式就可以了
  if fileexists(sfilename) then
   deletefile(sfilename);
  bs.savetofile(sfilename);
  olecontainer1.createobjectfromfile(sfilename,false);
  //olecontainer1.loadfromfile(sfilename);
  //olecontainer1.loadfromstream()
  //memo1.lines.loadfromfile(sfilename);
// webbrowser1.navigate(pchar(sfilename));
finally
  bs.free;
end;

上一篇:vc++中如何获取进程模块的信息
下一篇:java工具篇

[发送给好友] [打印本页] [关闭窗口] [返回顶部] 转载请注明来源:http://www.iyit.net
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 投稿作者: 易特网络技术
信息来源: 易特网络技术 录入时间: 2005-11-24 17:47:49
浏览次数: 投稿信箱: shtghy@163.com
  友情链接
设置首页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
copyrights ?2004-2005 iyit.net all rights reserved.
网站合作、广告联系qq:147007642、466949678
易特网络技术 点击这里给我发消息