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

文档

下载

图书

论坛

安全

源码

硬件

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

DELPHI存取JPEG文件到SQL Server数据库
发表日期:2003-07-23作者:高红岩[] 出处:  

近日笔者书写一个小型的学生管理系统时,需要用到ADO控件存取SQL Server数据库图片,查看资料发现基本都是针对BMP文件进行操作(巨增数据库大小),但发现了★eagletian★高手翻译的ADO英文技术文档,里面涉及到了数据库存取JPEG文件的关键技术,在win98+sql server桌面版中测试通过,运行良好,现于源码公开如下:

unit Unit1;

interface

uses

 Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,

 ExtCtrls, DBCtrls, Grids, DBGrids, Db, ADODB,jpeg, StdCtrls,dbtables;

  {一定要USES JPEG单元,使能存储JPG文件格式}

type

 TForm1 = class(TForm)

  DataSource1: TDataSource;

  ADOQuery1: TADOQuery;

  DBGrid1: TDBGrid;

  DBNavigator1: TDBNavigator;

  Image1: TImage;

  savebutton: TButton;

  showbutton: TButton;

  OpenDialog1: TOpenDialog;

  ADOQuery1id: TIntegerField;

  ADOQuery1pic: TBlobField;

  procedure savebuttonClick(Sender: TObject);

  procedure showbuttonClick(Sender: TObject);

  procedure DBNavigator1Click(Sender: TObject; Button: TNavigateBtn);

 private

  { Private declarations }

 public

  { Public declarations }

 end;

var

 Form1: TForm1;

implementation

{$R *.DFM}

function JpegStartsInBlob(PicField:TBlobField):integer;

  var

  ghy: TADOBlobstream;

  buffer:Word;

  hx: string;

  begin

  Result := -1;

  ghy := TADOBlobstream.Create(PicField, bmRead);

  try

   while (Result = -1) and (ghy.Position + 1 < ghy.Size) do

   begin

   ghy.ReadBuffer(buffer, 1);

   hx:=IntToHex(buffer, 2);

   if hx = ’FF’ then begin

    ghy.ReadBuffer(buffer, 1);

    hx:=IntToHex(buffer, 2);

   if hx = ’D8’ then Result := ghy.Position - 2

    else if hx = ’FF’ then

       ghy.Position := ghy.Position-1;

   end; //if

   end; //while

   finally

   ghy.Free

   end; //try

  end;

procedure TForm1.savebuttonClick(Sender: TObject);

var

picstream:tadoblobstream;

begin

adoquery1.edit;

picstream:=tadoblobstream.Create(tblobfield(adoquery1.fields[1]),bmWrite);

if form1.opendialog1.execute then

begin

picstream.LoadFromFile(opendialog1.filename);

picstream.Position:=0;

adoquery1.edit;

tblobfield(adoquery1.Fields[1]).loadfromstream(picstream);

adoquery1.post;

end;

end;

procedure TForm1.showbuttonClick(Sender: TObject);

var

ghy:TADOBlobstream;

pic:tjpegimage;

begin

ghy := TADOBlobstream.Create(Adoquery1pic, bmRead);

try

 ghy.Seek(JpegStartsInBlob(Adoquery1pic),soFromBeginning);

 Pic:=TJpegImage.Create;

 try

  Pic.LoadFromStream(ghy);

  Image1.Picture.Graphic:=Pic;

 finally

  Pic.Free;

 end;

finally

ghy.Free

end;

end;

procedure TForm1.DBNavigator1Click(Sender: TObject; Button: TNavigateBtn);

begin

if button in [nbFirst, nbPrior, nbNext, nbLast] then showbutton.Click;

end;

end.

如果数据库中要存储的是BMP文件,则在procedure TForm1.showbuttonClick(Sender: TObject);过程中代码更改如下即可存储显示BMP文件格式的操作。

procedure TForm1.showbuttonClick(Sender: TObject);

var

ghy:TADOBlobstream;

pic:tbitmap;

begin

ghy := TADOBlobstream.Create(Adoquery1pic, bmRead);

try

{ ghy.Seek(JpegStartsInBlob(Adoquery1pic),soFromBeginning);}

 Pic:=Tbitmap.Create;

 try

  Pic.LoadFromStream(ghy);

  Image1.Picture.Graphic:=Pic;

 finally

  Pic.Free;

 end;

finally

ghy.Free

end;

end;

  到此用DELPHI存取JPEG文件到SQL Server数据库中的具体操作已经叙述完毕。

我的网站:

http://delphijl.99898.com

QQ:123168091

我来说两句】 【发送给朋友】 【加入收藏】 【返加顶部】 【打印本页】 【关闭窗口
中搜索 DELPHI存取JPEG文件到SQL Server数据库

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

最新招聘信息

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