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

2011計算機等考二級Delphi輔導講義:SQL編程

來源:考試吧Exam8.com) 2010-10-29 11:11:15 考試吧:中國教育培訓第一門戶 模擬考場
本章主要介紹用Delphi開發(fā)簡單的數(shù)據(jù)庫應用程序的一般方法和步驟,首先讓讀者對Delphi強勁的數(shù)據(jù)庫應用開發(fā)工具有一個直觀的印象,然后在此基礎上進行復雜的數(shù)據(jù)庫應用程序的設計。

  17.2.2 在TQuery部件中編寫簡單的SQL查詢命令

  在這一節(jié)里我們將學習如何使用TQuery部件編寫簡單的SQL查詢命令,并在Delphi 應用程序中實現(xiàn)SQL查詢。

  例如,如果我們想查詢出表Customer.DB中客戶的編號和公司名稱,我們按下列步驟來實現(xiàn):

 、僭趹么绑w中放置一個TQuery部件、一個TDataSource部件一個TDataGrid部件,并將它們連接起來

 、谠O置窗體TQuery 部件Query1的DatabaseName屬性值為DBDEMOS

 、垭p擊Object Inspector窗口中Query1的SQL 屬性, Delphi 將顯示 String List Editor窗口。

 、茉趫D17.3中的窗口中輸入SQL語句:

  Select CustNo,Company From Custormer;

 、輪螕鬙K按鈕,關閉String List Editor窗口。

  ⑥設置Query的Open屬性為True。

  17.3 SQL語言編程概述

  在Delphi應用程序中的SQL命令語句是包含在TQuery部件的SQL屬性中,TQuery部件的SQL屬性是TString類型的,也就是說SQL屬性值是一個字符串列表,這個字符串列表非常類似于一個字符串類型的數(shù)組,有關TString類型的信息請參看聯(lián)機幫助。在前一節(jié)里我們介紹了TQuery部件可以執(zhí)行兩種SQL語句:

  ● 靜態(tài)SQL語句

  ● 動態(tài)SQL語句

  靜態(tài)SQL語句在程序設計時便已固定下來,它不包含任何參數(shù)和變量,例如下面的語句便是一條靜態(tài)SQL語句:

  Select * From Cusromer Where CustNo = 1234;

  而動態(tài)SQL語句,也被稱作參數(shù)化的語句,在其中間包含著表示字段名或表名的參數(shù),例如下面的語句是一條動態(tài)SQL語句:

  Select * From Customer Where CustNo =: Number;

  其中的變量Number便是一個參數(shù)變量,它由一個冒號引導,在程序運行過程中,必須要為該參數(shù)賦值,該條SQL語句才能正確執(zhí)行,每次運行應用程序時可以為該參數(shù)變量賦予不同的值。

  17.3.1 SQL命令文本的編寫

  1. 使用String List Editor編寫

  我們要為TQuery部件的SQL屬性設置SQL命令文本時,可以在應用窗體中選擇TQuery部件且雙擊Object Inspector窗口中的SQL屬性,這樣便打開了String List Editor 窗口,在該窗口中我們便可以編寫各種SQL命令,如圖17.3所示。

  在編寫完適當?shù)腟QL語句之后,選擇 OK 按鈕便可以將編輯器中的 SQL 命令文裝入到TQuery部件的SQL屬性中,選擇SAVE按鈕可以將編寫好的SQL命令保存到一個文件中供以后編程時使用。我們在編寫SQL命令文本時還可以選擇Load按鈕從一個 SQL 命令文件中調入SQL命令。在程序運行過程中,要想設置TQuery部件的SQL屬性,必須首先調用Close方法,關閉TQuery部件,然后再調用Clear方法清除SQL屬性中現(xiàn)存的SQL命令語句,最后再調用Add方法為SQL屬性設置新的SQL命令語句。例如:

  Query1.Close {關閉Query1)

  Query1.SQL.Clear {清除SQL屬性中的SQL命令語句}

  Query1.SQL.Add('Select * From Country');

  Query1.SQL.Add('Where Name ="ARGENTINA" ');

  在為TQuery部件設置SQL屬性時調用Close方法總是很安全的,如果TQuery部件已經被關閉了,調用Close方法時不會產生任何影響。在應用程序中為SQL屬性設置新的SQL 命令語句時,必須要調用Clear方法以清除SQL屬性中現(xiàn)存的SQL命令語句,如果不調用Clear方法,便調用Add方法向SQL屬性中設置SQL命令語句,那么新設置的SQL命令語句會追加在現(xiàn)存SQL命令語句后面,在程序運行時常常會出現(xiàn)出乎意料的查詢結果甚至程序無法運行下去。

  在這里要特別注意的,一般情況下TQuery部件的SQL屬性只能包含一條完整的SQL語句,它不允許被設置成多條SQL語句。當然有些數(shù)據(jù)庫服務器也支持在TQuery部件的SQL屬性中設置多條SQL語句,只要數(shù)據(jù)庫服務器允許這樣,我們在編程時可以為 SQL 屬性設置多條SQL語句。

  2. 使用Visual Query Builder編寫

  客戶/服務器版本的Delphi還包含一個可視化的查詢構造器Visual Query Builder ,用這個可視化的工具我們只能編寫Select語句。在應用程序窗體中選擇TQuery部件后,單擊鼠標右鍵,彈出一個彈出式菜單,從中選擇Run Visual Query Builder后便會彈出一對話框提示你選擇要訪問的數(shù)據(jù)庫,選擇想要訪問的數(shù)據(jù)庫之后選擇OK按鈕,緊接著會出現(xiàn)一個彈出式對話框提示你選擇要查詢的數(shù)據(jù)庫表,一次可以選擇多個數(shù)據(jù)庫表,若要選擇多個數(shù)據(jù)庫表,每選擇一個表之后單擊Add按鈕,接著選擇另一個表,選擇完要查詢的表之后單擊Close按鈕,這樣,可視化的查詢構造器中將會顯示出用戶選擇的數(shù)據(jù)庫表。

  有關如何使用可視化的查詢構造器Visual Query Builder 請參看聯(lián)機幫助信息, 在Visual Query Builder中構造完一個查詢并退出Visual Query Builder時,其中的SQL 命令語句會自動地寫入相應的TQuery部件的SQL屬性。

上一頁  1 2 3 4 5 6 7 8 下一頁
  相關推薦:2010年9月計算機等級考試試題及答案解析專題
       預告:名師解析2010年9月計算機等級考試試題答案
       2010年9月計算機等級考試成績查詢時間及入口
       2010年9月計算機等考成績查詢短信免費提醒開通
文章搜索
版權聲明:如果計算機等級考試網(wǎng)所轉載內容不慎侵犯了您的權益,請與我們聯(lián)系800@exam8.com,我們將會及時處理。如轉載本計算機等級考試網(wǎng)內容,請注明出處。