狠狠爱成人网_日韩一级在线_国产综合自拍_亚洲精品韩国_亚洲视频导航_麻豆成人在线播放_欧美jjzz_一区在线视频观看_美脚丝袜一区二区三区在线观看_欧美91视频

當前位置:系統之家 > 技術開發教程 > 詳細頁面

Delphi處理SQL Server數據

Delphi處理SQL Server數據

更新時間:2019-09-24 文章作者:未知 信息來源:網絡 閱讀次數:

  筆者日前參與開發了一套高速公路收費系統,主要功能是記錄通過收費站的所有車輛的信息,包括時間、車型、金額、車輛圖片資料等,其中涉及到多媒體數據的處理。下面筆者將主要依靠Delphi中的流數據類型來為大家做講解。

  一、選擇數據庫

  1.問題

  常用的桌面型數據庫,如Access、Visual FoxPro等,使用比較簡單,也可以管理多媒體信息。但由于數據庫引擎不夠強大,在管理少量多媒體數據時尚能正常運行,當數據量增大到一定程度后,數據庫的反應就會變得異常緩慢,其性能也大幅下降。在達到某個臨界點時,甚至還會出現數據庫處理能力和待處理數據量的嚴重失衡,而導致假死狀況的出現。筆者有過這樣的經驗,用Visual Fox Pro來管理1萬名學生的照片檔案和學籍信息,這時要進行查詢必須經過長時間等待,最后不得不放棄。

  2.治“標”

  用一些技巧可以加快系統的運行,比如“化整為零”法。即將超大數據分散到眾多數據表中,雖然可以有效地提高數據庫的運行速度,但層次過多使查詢、統計等變得十分不便,而且編程的復雜度和工作量也會隨之大幅增加。

  另外一個常用方法是將多媒體數據保存為獨立的文件,在數據庫中只存儲這些文件的路徑和文件名,從而避免了將海量數據直接存入數據庫。這種為數據庫減負瘦身的方法可用于任何數據庫,通用性好,而且對性能的提升也是可觀的,是一種已經得到廣泛應用的治“標”方法。然而這種方法也有明顯的缺點:結構復雜、不便維護、安全性差,更體現不出數據庫的優點。還是以學籍管理為例,采用這種方法管理1萬甚至更多學生的照片數據,程序非常復雜,維護也十分困難,依然不是治“本”之策。

  3.治“本”

  其實,要處理海量的多媒體數據,再先進的桌面型數據庫都會捉襟見肘,筆者最后采用了企業級數據庫。以SQL Server、Sybase、Oracle等為代表的企業級數據庫具有更強大的性能、更完善的數據管理、更可靠的安全特性和更出色的網絡功能,能夠勝任非常復雜和龐大的數據管理任務,同時它們還提供了豐富的數據類型,以及針對多媒體管理特別優化的引擎。考慮綜合性能、價格等各方面的因素,我們最終選擇SQL Server 2000標準版作為系統的后臺數據庫。
  二、怎樣處理多媒體數據

  1.多媒體數據的存儲

  多媒體信息包括圖像、聲音和視頻等,它們都是以二進制數據集合的形式存在的,在本系統中處理的對象是圖像。SQL Server提供了Image數據類型來存儲可變長度二進制數據(大小范圍為0~2GB)。但Image字段并不能將多媒體數據直接裝入,必須經過一些中間步璨拍芙荽娼ァO旅嬉醞枷袷蕕拇媧⑽蠹醫檣茉躚贒elphi中實現這些中間步驟。

  Delphi中的TStream數據類型以流的形式對字符或非字符數據進行存儲,就像在內存中開辟了一個大小可變的臨時緩存區。它不僅能方便地對外部文件進行讀寫,而且還可以將流中的全部數據直接轉入數據庫,所以用它作橋梁來完成數據存入工作是非常合適的。

  下面的SavetoImage函數的功能是將TStream數據存入數據表的Image字段中。

function SavetoImage(const Stream:TStream;const AField:TField):boolean;
var
FieldStr:string;
PFieldStr:PChar;
begin
Result:=false;
if (Assigned(AField)) and (Assigned(Stream)) then
begin
try
Stream.Seek(0,0);
SetLength(FieldStr,Stream.Size);
PFieldStr:=PChar(FieldStr);
Stream.Read(PFieldStr^,Stream.Size);
AField.Value:=FieldStr;
Result:=true;
except
end;
end;
end;

  下面是調用SavetoImage函數完成圖像數據存儲的程序片段。

Var
FS:TFileStream;
begin
FS:=TFileStream.Create('C:\Car001.jpg',fmOpenRead);
SavetoImage(FS,Adodataset1.FieldBy
Name('st_img'));
FS.Free;
end;

  其中,Adodataset1是與數據庫進行連接的ADO數據集控件,st_img為Image字段。

  2.多媒體數據的轉移

  利用SQL Server所帶的BCP實用工具,可以很方便地將數據庫部分或全部數據復制出來,包括二進制數據。對復制出的多媒體數據可以通過網絡或移動存儲設備將它們轉移到遠端的監控電腦上,再利用BCP將它們復制到監控數據庫中,以便對多媒體數據進行回放或做其它處理。下面是簡化了的將數據從數據庫復制到外部文件和從外部文件復制入數據庫的程序片段。

var
s1:string;
begin
s1:='bcp "select * from st2002..st2002_sf where st_flag=1" queryout c:\Media_data.dat -N -P -S sunnynt\hy2002';
winexec(PChar(s1),sw_show);
end;

  其中“select * from st2002..st2002_sf where st_flag=1”表示從st2002數據庫的st2002_sf表中提取數據,“c:\Media_data.dat”為輸出數據文件,參數queryout表示從查詢中復制數據到外部文件,-N表示進行大容量數據復制操作,-P表示使用默認密碼,-S提定進行數據復制操作的數據庫服務器或實例。

var
s1:string;
begin
s1:= 'bcp ST2002..ST2002_SF in c:\Media_data.dat -n -E -P -S sunnynt \hy2002';
winexec(PChar(s1),sw_show);
end;

  其中參數in表示將數據從外部文件復制到數據表中。

  3.多媒體數據的回放

  同存儲的方法類似,多媒體數據的回放也要借助TStream數據類型作橋梁,而且它基本上是存儲的逆過程。

  LoadfromImage函數的功能是將數據表的Image字段數據裝入TStream中。

function LoadfromImage(const AField:TField;const Stream:TStream):boolean;
var
ResultStr:string;
PResultStr:PChar;
begin
Result:=false;
if (Assigned(AField)) and (Assigned(Stream)) then
begin
try
ResultStr:=AField.Value;
PResultStr:=PChar(ResultStr);
Stream.Write(PResultStr^,length(Result
Str));
Stream.Seek(0,0);
Result:=True;
except
end;
end;
end;

  下面是調用LoadfromImage函數將數據表Image字段中的圖像數據轉出到外部文件中并利用圖像顯示控件回放圖像的程序片段。

var
FS:TFileStream;
begin
FS:=TFileStream.Create('c:\Car001.jpg',fmCreate);
LoadfromImage(adodataset1.fieldby
name('st_img'),FS);
FS.Free;
image1.picture.LoadFromFile('c:\Car001.jpg');
end;

  三、小結

  其它多媒體數據類型如聲音、視頻等的轉出過程與圖像的轉出完全相同,只是回放部分應針對不同媒體類型采用不同的媒體播放控件。

  上面所述的原型程序在Delphi 5/6/7+SQL Server 2000標準版中調試通過,經過適當的擴充和修改后,這些程序在筆者開發的高速公路收費系統中得到了驗證。同樣,這些程序也可使用在如學籍管理、檔案管理、人事管理、商品交易等涉及到多媒體數據的應用系統中。

  如今已經是數碼時代,DC、DV、MP3等數碼設備正逐漸深入到我們生活和工作中,它們產生的圖像、視頻、聲音等多媒體信息呈爆炸式增長,如何有效管理這些多媒體信息成為擺在我們面前的課題。本文簡單討論了利用SQL Server數據庫對多媒體信息進行管理的幾個基本問題,其原理同樣適合Sybase、Oracle等數據庫和Powerbuilder、VB等前端開發工具。

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統下載排行

狠狠爱成人网_日韩一级在线_国产综合自拍_亚洲精品韩国_亚洲视频导航_麻豆成人在线播放_欧美jjzz_一区在线视频观看_美脚丝袜一区二区三区在线观看_欧美91视频
久久国产精品免费一区| 欧美亚洲日本国产| 91在线国内视频| 国产一区二区在线看| 男人的天堂久久精品| 日日夜夜精品视频免费| 午夜av一区二区三区| 午夜精品久久久久久久蜜桃app| 一区二区视频在线| 亚洲一区二区成人在线观看| 一区二区视频在线看| 一区二区三区.www| 亚洲成人精品影院| 麻豆专区一区二区三区四区五区| 青青草国产精品97视觉盛宴| 日韩精品乱码免费| 精品亚洲国内自在自线福利| 国产在线精品一区二区夜色| 高清beeg欧美| 欧美三级特黄| 夜夜嗨网站十八久久| 久久精品欧洲| 欧美日韩国产综合一区二区三区| 欧美一区二区三区人| 亚洲精品在线观看视频| 国产欧美va欧美不卡在线| 亚洲欧美福利一区二区| 天天操天天干天天综合网| 久久er精品视频| 成人av第一页| 一本色道久久综合一区 | 久久精品视频在线免费观看| 中文字幕一区在线观看| 日韩电影一区二区三区四区| 精品在线亚洲视频| 91美女片黄在线| 国产亚洲欧美一区二区| 欧美日韩大陆一区二区| 国产午夜精品一区二区三区嫩草 | 91黄色免费网站| 欧美成人一区二区| 亚洲欧美国产毛片在线| 久久99精品久久久久久| 午夜精品视频| 91福利精品视频| 久久伊人中文字幕| 亚洲国产中文字幕| 东方aⅴ免费观看久久av| 亚洲精品一级| 欧美二区三区91| 亚洲欧美一区二区三区久本道91| 毛片一区二区三区| 在线精品亚洲| 777久久久精品| 亚洲精品日日夜夜| 国产·精品毛片| 性欧美暴力猛交另类hd| 欧美www视频| 日韩电影在线看| 亚洲午夜精品国产| 欧美一区二区免费视频| 洋洋成人永久网站入口| 成人免费av网站| 在线观看成人免费视频| 中文一区二区完整视频在线观看| 老司机精品视频一区二区三区| 国产精品扒开腿做爽爽爽软件| 欧美性大战久久久久久久蜜臀| 中文字幕视频一区| 不卡的电影网站| 欧美日韩国产小视频| 一区二区三区中文字幕电影| 99re8在线精品视频免费播放| 在线观看国产日韩| 性久久久久久久久久久久| 欧美日韩hd| 久久蜜桃香蕉精品一区二区三区| 老司机午夜精品99久久| 久久精品日产第一区二区三区| 中文字幕一区二区三区视频| 成人黄色一级视频| 欧美一级免费观看| 久久99精品久久久久| 久久婷婷激情| 亚洲综合成人网| 亚洲国产精品第一区二区三区| 久久久精品国产免费观看同学| 国产最新精品免费| 欧美日韩一区在线观看| 日韩va欧美va亚洲va久久| 国产欧美日韩在线播放| 自拍偷拍亚洲激情| 在线观看日韩av电影| 久久久精品免费网站| 欧美一区免费视频| 久久精品亚洲精品国产欧美kt∨| jizzjizzjizz欧美| 亚洲精品一区二区三区四区高清| 国产99精品国产| 精品日韩一区二区三区| 成人美女视频在线观看18| 日韩精品资源二区在线| 成人妖精视频yjsp地址| 精品精品欲导航| 97超碰欧美中文字幕| 久久久久久免费网| 午夜精品久久99蜜桃的功能介绍| 国产精品青草久久| 99亚洲一区二区| 亚洲1区2区3区视频| 久久一日本道色综合久久| 日韩国产在线一| 欧美日韩mp4| 成人午夜在线视频| 久久精品夜夜夜夜久久| 伊人久久婷婷| 亚洲成人tv网| 欧美另类久久久品| fc2成人免费人成在线观看播放| wwww国产精品欧美| 欧美婷婷在线| 亚洲午夜一区二区三区| 91久久精品国产91性色tv| 国产东北露脸精品视频| 亚洲国产精品成人综合 | 欧美丰满嫩嫩电影| 97久久精品人人做人人爽| 国产精品天天看| 香港久久久电影| 国产乱对白刺激视频不卡| 久久综合色天天久久综合图片| 欧美日韩亚洲在线| 天天综合天天做天天综合| 日韩亚洲欧美在线观看| 国模吧视频一区| 午夜激情久久久| 日韩欧美一级精品久久| 国产精品久久7| 麻豆91在线看| 日本一区二区三区免费乱视频| 在线综合亚洲| 国产精品一区二区三区四区| 欧美国产精品一区二区三区| 麻豆av福利av久久av| 成人午夜视频免费看| 亚洲黄色av一区| 精品免费一区二区三区| 国产日产精品一区二区三区四区的观看方式| 日韩va亚洲va欧美va久久| 久久久久久久久久久黄色| 久久av一区二区| 91美女精品福利| 美女被吸乳得到大胸91| 国产精品人人做人人爽人人添| 色噜噜狠狠一区二区三区果冻| 91网站在线播放| 久久99国产乱子伦精品免费| 国产精品国产三级国产普通话99| 欧美群妇大交群的观看方式| 国产一区二区三区四区三区四| 蜜桃视频在线一区| 亚洲摸摸操操av| 精品国产免费人成在线观看| 蜜桃av久久久亚洲精品| 国内视频精品| 波多野结衣91| 久久国产日韩欧美精品| 亚洲视频在线一区二区| 精品区一区二区| 欧美人牲a欧美精品| 亚洲一区影院| 好看不卡的中文字幕| 粉嫩av一区二区三区在线播放| 亚洲.国产.中文慕字在线| 欧美激情一区二区在线| 在线播放国产精品二区一二区四区 | 久久精品欧美一区二区三区麻豆| 欧美色男人天堂| 久久高清国产| 99精品视频免费| 欧美午夜不卡| 成人动漫在线一区| 国产在线麻豆精品观看| 免费视频最近日韩| 亚洲国产日日夜夜| 亚洲视频免费在线观看| 国产欧美日韩综合精品一区二区| 91麻豆精品国产91久久久资源速度 | 日韩免费一区二区| 欧美男同性恋视频网站| 久久综合狠狠综合久久综青草| 亚洲精华国产欧美| 欧美人成在线| 欧美日韩18| 国模精品娜娜一二三区| 欧美黄色aaaa| 欧美精品入口| 91色porny在线视频| 99久久久国产精品| 91香蕉视频在线|