首頁 考試吧論壇 Exam8視線 考試商城 網(wǎng)絡(luò)課程 模擬考試 考友錄 實(shí)用文檔 求職招聘 論文下載
2011中考 | 2011高考 | 2012考研 | 考研培訓(xùn) | 在職研 | 自學(xué)考試 | 成人高考 | 法律碩士 | MBA考試
MPA考試 | 中科院
四六級 | 職稱英語 | 商務(wù)英語 | 公共英語 | 托福 | 雅思 | 專四專八 | 口譯筆譯 | 博思 | GRE GMAT
新概念英語 | 成人英語三級 | 申碩英語 | 攻碩英語 | 職稱日語 | 日語學(xué)習(xí) | 法語 | 德語 | 韓語
計(jì)算機(jī)等級考試 | 軟件水平考試 | 職稱計(jì)算機(jī) | 微軟認(rèn)證 | 思科認(rèn)證 | Oracle認(rèn)證 | Linux認(rèn)證
華為認(rèn)證 | Java認(rèn)證
公務(wù)員 | 報(bào)關(guān)員 | 銀行從業(yè)資格 | 證券從業(yè)資格 | 期貨從業(yè)資格 | 司法考試 | 法律顧問 | 導(dǎo)游資格
報(bào)檢員 | 教師資格 | 社會工作者 | 外銷員 | 國際商務(wù)師 | 跟單員 | 單證員 | 物流師 | 價(jià)格鑒證師
人力資源 | 管理咨詢師考試 | 秘書資格 | 心理咨詢師考試 | 出版專業(yè)資格 | 廣告師職業(yè)水平
駕駛員 | 網(wǎng)絡(luò)編輯
衛(wèi)生資格 | 執(zhí)業(yè)醫(yī)師 | 執(zhí)業(yè)藥師 | 執(zhí)業(yè)護(hù)士
會計(jì)從業(yè)資格考試會計(jì)證) | 經(jīng)濟(jì)師 | 會計(jì)職稱 | 注冊會計(jì)師 | 審計(jì)師 | 注冊稅務(wù)師
注冊資產(chǎn)評估師 | 高級會計(jì)師 | ACCA | 統(tǒng)計(jì)師 | 精算師 | 理財(cái)規(guī)劃師 | 國際內(nèi)審師
一級建造師 | 二級建造師 | 造價(jià)工程師 | 造價(jià)員 | 咨詢工程師 | 監(jiān)理工程師 | 安全工程師
質(zhì)量工程師 | 物業(yè)管理師 | 招標(biāo)師 | 結(jié)構(gòu)工程師 | 建筑師 | 房地產(chǎn)估價(jià)師 | 土地估價(jià)師 | 巖土師
設(shè)備監(jiān)理師 | 房地產(chǎn)經(jīng)紀(jì)人 | 投資項(xiàng)目管理師 | 土地登記代理人 | 環(huán)境影響評價(jià)師 | 環(huán)保工程師
城市規(guī)劃師 | 公路監(jiān)理師 | 公路造價(jià)師 | 安全評價(jià)師 | 電氣工程師 | 注冊測繪師 | 注冊計(jì)量師
繽紛校園 | 實(shí)用文檔 | 英語學(xué)習(xí) | 作文大全 | 求職招聘 | 論文下載 | 訪談 | 游戲

2011計(jì)算機(jī)等考Delphi:數(shù)據(jù)庫創(chuàng)建及MASTAPP介紹

本章主要介紹用Delphi開發(fā)簡單的數(shù)據(jù)庫應(yīng)用程序的一般方法和步驟,首先讓讀者對Delphi強(qiáng)勁的數(shù)據(jù)庫應(yīng)用開發(fā)工具有一個(gè)直觀的印象,然后在此基礎(chǔ)上進(jìn)行復(fù)雜的數(shù)據(jù)庫應(yīng)用程序的設(shè)計(jì)。

  14.5.2 使用FindKey方法查找數(shù)據(jù)庫中的記錄

  雖然使用上面的Gotokey方法在數(shù)據(jù)庫中查找記錄效果不錯,但是Delphi 還提供了一種更加容易的查找方法,這就是Findkey方法,兩種方法雖然很相似,但是Findkey方法更簡單明了一些。

  例14.4 我們可以使Findkey方法代替上面例子中的處理程序,下面是程序代碼:

  procedure TForm1.Button1OnClick(Sender:TObject);

  var

  SeekValue:string;

  begin

  with Table1 do

  begin

  Label1.Caption:=' ';

  Label1.Caption:=' ';

  IndexFieldName:='CustNo';

  SeekValue:=Edit1.Text;

  If FindKey([SeekValue]) then

  begin

  Label1.Caption:='查找成功';

  Label1.Caption:=FieldByName('Phone').AsString;

  end;

  else

  Label1.Caption:='查找失敗';

  end;

  Findkey方法和Gotokey方法的根本區(qū)別在于查找值要作為參數(shù)傳遞給Findkey 函數(shù)。而GOtokey是不帶參數(shù)的,它假定用戶已經(jīng)把查找值賦給了代表著被查找到的字段的查找緩沖區(qū)。

  Findkey接受的參數(shù)是放在方括號中的,是用逗號分開的查找值數(shù)組。數(shù)組中的每一個(gè)值都對應(yīng)于特定列的查找值,即參數(shù)中允許有多個(gè)查找值,F(xiàn)indkey 允許用戶同時(shí)查找數(shù)據(jù)庫表中的多個(gè)列。上面的程序清單中的Findkey函數(shù)只接受了變量Seekvalue這一個(gè)查找值,這個(gè)查找值對應(yīng)表中的字段CustNo,CustNo是表中的關(guān)鍵字段。如果要同時(shí)查找表中的多個(gè)字段,必須把要查找的多個(gè)字段名賦給TTable部件的IndexFieldName屬性,并用逗號分開各字段,然后把每個(gè)字段的查找值賦給Findkey的參數(shù)數(shù)組中。

  14.5.3 利用GotoNearest和FindNearest執(zhí)行不精確查找

  在我們上面討論的查找中,要么查找成功要么查找失敗,因?yàn)槲覀儾檎业氖翘囟ú檎抑档囊粋(gè)精確匹配值。Delphi還提供了一種查找方法,即不精確查找,這樣的查找絕對不會失敗,它總是給用戶查找出一個(gè)結(jié)果來,也許這結(jié)果并不是用戶需要的,但這個(gè)查找出來的結(jié)果是最接近用戶要求的。在Delphi中是利用GotoNearest和FineNearest兩種方法來執(zhí)行不準(zhǔn)確查找的,它們總是從數(shù)據(jù)庫中查找出與查找值最接近的匹配值。如果它們查找到與查找值精確匹配的值,那當(dāng)然最好不過了,如果他們找不到精確匹配的值,它們就會把與用戶指定的查找值最接近的記錄提交給用戶。

  GotoNearest的使用方法和Gotokey一樣,F(xiàn)indNearest的使用方法和Findkey一樣。跟Gotokey一樣,使用GotoNearest時(shí)必須要把查找值賦給字段的查找緩沖區(qū),兩者的不同之處在于查找值的說明方式不一樣,使用GotoNearest時(shí),說明的查找值可以是完整的也可以是不完整的,如果要對'Dunteman'進(jìn)行不精確查找,在給字段的查找緩沖區(qū)賦查找值時(shí),可以使用'Dunteman'、'Dun'或者`Du'作為查找值,這樣查找出來的結(jié)果會盡可能地接近這個(gè)值的。

  如果沒有找到與用戶指定的查找值精確匹配的記錄,Delphi會調(diào)整記錄指針并停留在與查找值最接近的第一個(gè)記錄上。例如如果查找`Dunteman'時(shí),沒有找到精確匹配的值,記錄指針可能會停留在`Dunwoody'上或者停留在更遠(yuǎn)一些的'Event'上;如果查找'Du' 沒有找到精確匹配的值,記錄指針可能停留在‘Duncan’上,甚至‘Dunteman'之前,總之Delphi會自己地調(diào)整記錄指針,使之指向最接近查找值的記錄并將該記錄作為查找的結(jié)果提交給用戶。

  GotoNearest和FindNearest都返回一個(gè)Boolean值以表明查找是否成功。它們一般都是成功的,它們總是要把記錄指針移到某處。

  下面的例子是用GotoNearest方法進(jìn)行不精確查找。

  例14.5 創(chuàng)建好的窗體,在編輯框中輸入一個(gè)不完整的客戶所在的公司名稱,并且按“不精確查找”按鈕,然后觀察一下查找的結(jié)果并注意記錄指針指向那一條記錄。反復(fù)試驗(yàn)幾次便會理解GotoNearest是如何工作的。

  利用GotoNearest方法執(zhí)行不精確查找

  窗體中的“不精確查找”按鈕的事件處理過程代碼如下:

  procedure TForm1.Button1Click(Sender: TObject);

  begin

  with table1 do

  begin

  IndexFieldNames:='Company';

  setkey;

  FieldByName('Company').AsString:=Edit1.text;

  GotoNearest;

  label3.caption:=FieldByName('Company').AsString;

  end;

  end;

  讀者可以利用 FindNearest 方法執(zhí)行上面的不精確查找, 具體使用方法可以參看Findkey方法的使用。

  在上面的例子中要設(shè)置table1的IndexFieldNames屬性為Company。

  GotoNearest方法進(jìn)行不精確查找

  相關(guān)推薦:2010年9月計(jì)算機(jī)等級考試試題及答案解析專題
       預(yù)告:名師解析2010年9月計(jì)算機(jī)等級考試試題答案
       2010年9月計(jì)算機(jī)等級考試成績查詢時(shí)間及入口
       2010年9月計(jì)算機(jī)等考成績查詢短信免費(fèi)提醒開通
文章搜索
版權(quán)聲明:如果計(jì)算機(jī)等級考試網(wǎng)所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權(quán)益,請與我們聯(lián)系800@exam8.com,我們將會及時(shí)處理。如轉(zhuǎn)載本計(jì)算機(jī)等級考試網(wǎng)內(nèi)容,請注明出處。