登录社区:用户名: 密码: 忘记密码 网页功能:加入收藏 设为首页 网站搜索  

文档

下载

图书

论坛

安全

源码

硬件

游戏
首页 信息 空间 VB VC Delphi Java Flash 补丁 控件 安全 黑客 电子书 笔记本 手机 MP3 杀毒 QQ群 产品库 分类信息 编程网站
  立华软件园 - 安全技术中心 - 技术文档 - Delphi 技术文章 | 相关下载 | 电子图书 | 攻防录像 | 安全网站 | 在线论坛 | QQ群组 | 搜索   
 安全技术技术文档
  · 安全配制
  · 工具介绍
  · 黑客教学
  · 防火墙
  · 漏洞分析
  · 破解专题
  · 黑客编程
  · 入侵检测
 安全技术工具下载
  · 扫描工具
  · 攻击程序
  · 后门木马
  · 拒绝服务
  · 口令破解
  · 代理程序
  · 防火墙
  · 加密解密
  · 入侵检测
  · 攻防演示
 安全技术论坛
  · 安全配制
  · 工具介绍
  · 防火墙
  · 黑客入侵
  · 漏洞检测
  · 破解方法
 其他安全技术资源
  · 攻防演示动画
  · 电子图书
  · QQ群组讨论区
  · 其他网站资源
最新招聘信息

也来谈谈数据库中的图象存取
发表日期:2003-03-16作者:DavidLove[] 出处:  

  关于数据库中的图象存取,网上的资料多是直接用Table或者Query 等控件然后利用流作为媒介来完成。目前我还没看到封装在一个类里面,完全用SQL语句来实现图象的存取。前段时间开发一个运证管理系统就碰到了这样一个问题:要把每个司机的照片入库。我们可以在主界面放置一个TImage和OpenDialog对话框进行照片的选择,可是最后怎样将照片存入数据库呢?下面提供源代码让大家分析(其中删去了一些不相关的东西):

THuman=class (TComponent) Private

Name:string;

IDCard:string;

Sex:Byte;

Photo:TImage;

FQuery:TQuery;

FDatabase:TDatabase;-

- -publisned

property Name:string read FName write FName;

property IDCard:string read FIDCard write FIDCard;

property Sex:Byte read FSex write FSex;

property Photo:TImage read FPhoto write FPhoto;

property Query:TQuery read FQuery write FQuery;

property Database:TDatabase read FDatabase write FDatabase;function THuman.Insert: Boolean;var

Sqlstr:string;

lStream:TMemoryStream;

lPicture:TJPEGImage;begin

lStream:=TMemoryStream.Create;

lPicture:=TJPEGImage.Create;// FPhoto为TImage变量,在主界面可以选择一张照片

if FPhoto.Picture.Graphic<>nil then

begin

lPicture.Assign(FPhoto.Picture.Graphic);

lPicture.SaveToStream(lStream);

end;

if FDatabase.InTransaction then FDatabase.Commit;

FDatabase.StartTransaction;

Query.Sql.text:= 'Insert Into Human(Name,IDCard,Sex,Photo) values(:Name,:IDCard,:Sex,:Photo)’;

子段前加冒号,动态生成SQL参数,然后给参数赋值:

Query.ParamByName('Name').asstring:=’张家恶少’;

Query.ParamByName('IDCard').asstring:=Something;

Query.ParamByName('Sex').asstring:=Something;

Query.ParamByName('Photo').LoadFromStream(lStream,ftBlob);

try

Query.Prepare;

Query.execSQL;

Query.Close;

FreeAndNil(lStream);

FreeAndNil(lPicture);

Result:=True;

FDatabase.Commit;

except

FDatabase.Rollback;

Query.Close;

FreeAndNil(lStream);

FreeAndNil(lPicture);

Result:=False;

end;

最后要主要释放动态生成的LStream 和 LPicture

我来说两句】 【发送给朋友】 【加入收藏】 【返加顶部】 【打印本页】 【关闭窗口
中搜索 也来谈谈数据库中的图象存取

 ■ [欢迎对本文发表评论]
用  户:  匿名发出:
您要为您所发的言论的后果负责,故请各位遵纪守法并注意语言文明。

最新招聘信息

关于我们 / 合作推广 / 给我留言 / 版权举报 / 意见建议 / 广告投放 / 友情链接  
Copyright ©2001-2006 Lihuasoft.net webmaster(at)lihuasoft.net
网站编程QQ群   京ICP备05001064号 页面生成时间:0.0019