六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

數據庫中圖像數據的存取技術

[摘要]數據庫應用程序開發中圖像數據的存取技術 Delphi提供了數據訪問(DataAccess)和數據控制(DataControls)的可視化控件,能夠方便快捷地產生具有良好界面且功能強大的數據庫應用程序。對于涉及圖像數據(含Graphic字段)的數據庫應用程序,如人事管理信息系統等,圖像數據的存取技術...
數據庫應用程序開發中圖像數據的存取技術

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;



主站蜘蛛池模板: 性感美女视频黄.免费网站 性感保姆正片 | 亚洲视频在线观看一区 | 日韩a在线观看 | 色综合久久综合网欧美综合网 | 青青草一区国产97 | 午夜一级福利 | 新男人天堂 | 一二三四影院免费 | 日本深夜福利视频 | 亚洲欧美综合色区小说 | 青娱乐免费视频在线观看 | 在线91精品国产免费 | 最近2019中文字幕大全视频一页 | 一二三四手机在线观看视频播放 | 手机三级在线 | 四虎影视www四虎免费 | 五月婷婷深爱 | 一级女性全黄久久生活片 | 日韩 欧美 国产 亚洲 中文 | 日本在线视频免费 | 狍和女人一级毛片 | 一级毛片免费毛片一级毛片免费 | 日韩黄色一级 | 日韩福利视频 | 亚洲欧洲在线观看 | 日本美女视频韩国视频网站免费 | 亚洲国产成人久久一区二区三区 | 色老头久久久久 | 日本亚洲精品色婷婷在线影院 | 中文字幕在线乱人伦 | 爽爽影院在线看 | 日本网址在线观看 | 欧美综合久久 | 欧美野外多人交3 | 日本xxx在线 | 亚洲成人一级片 | 色网在线观看 | 香港三级欧美国产精品 | 天天插日日射 | 欧美亚洲网站 | 四虎com|