网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Delphi
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.在delhpi程序中获取网络资源信息.
.Delphi&BCB一线程序员开.
.TChart使用经验小结.
.取得自从开机到现在CPU运行的周期.
.Delphi7对XML的支持分析.
.Delphi随笔一.
.ADO方式下判断数据表是否存在.
.delphi编译错误信息.
.Delphi的接口陷阱.
.绑架窗体之Delphi版.
.浅谈控件(组件)制作方法一(附带.
.在Dephi中使用TStream读写数据的.
.两个delphi下遍历指定目录下指定.
.BORLAND第三方组件安装方法.
.组件制作之一(概念).
.Delphi中对象解除技巧.
.研究心得------->Seskin控.
.纸牌控件的编写(下).
.字存为字符图片.
.性能vs结构.

数据库应用程序开发中图像数据的存取技术

发表日期:2006-2-4


数据库应用程序开发中图像数据的存取技术 
  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.建立窗体,设置窗体中各控件的属性。

  该窗体的主要功能是将某人信息进行编辑和保存。需要注意的图像保存所用的图像框必须用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);
  begin
      opendialog1.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的属性的设置与数据的保存部分相同,所不同的是数据库数据的读取时用TDBEdit和TDBImage控件而不用TEdit和TImage。控件TDBEdit和TDBImage只要将datafield属性设置为其相对应的域;TDBNavigator的datasouce属性设置为datasource1即可。 

上一篇:在Dephi中使用TStream读写数据的技巧 人气:5106
下一篇:自定义快速报表的打印预览窗口 人气:3977
浏览全部Delphi的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐