版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、6.6 嵌入式SQL編程了解SQL與宿主語言的關(guān)系理解嵌入式SQL的處理過程理解嵌入式SQL與主語言之間的通信掌握嵌入SQL的使用方式【本節(jié)的主要內(nèi)容】一、嵌入式SQL與宿主語言(1)SQL語言具有很強的查詢處理能力,而邏輯表達(dá)的能力很弱,界面編程能力也很弱。(2)如JAVA,C/C+等高級語言具有很強邏輯表達(dá)能力,能實現(xiàn)復(fù)雜的處理邏輯,同時具有較強的用戶界面實現(xiàn)功能。(3)為了使程序語言同時具有它的優(yōu)點,在JAVA、C/C+等高級語言中嵌入SQL語句,稱高級語言為宿主語言。(4)由DBMS的預(yù)編譯器掃描識別處理SQL語句,把SQL語句轉(zhuǎn)換成主語言調(diào)用語句,以使主語言編譯程序能識別它,最后由主
2、語言的編譯程序?qū)⒄麄€源程序編譯成目標(biāo)碼,然后連接(Link)處理生成裝載模塊。二、嵌入式SQL的處理過程(1)嵌入式SQL是一個語句級接口,通過程序訪問的數(shù)據(jù)庫模式必須在編寫程序時已知,以便構(gòu)造SQL語句。例如,程序員必須知道數(shù)據(jù)表名稱、列名稱及它的域。(2)對于嵌入式SQL,RDBMS一般采用預(yù)編譯方法處理,即由RDBMS的預(yù)處理程序?qū)υ闯绦蜻M(jìn)行掃描,識別出嵌入的SQL語句,把它們轉(zhuǎn)換成主語言調(diào)用語句,以使主語言編譯程序能識別它們,然后由主語言的編譯程序?qū)⒓兊闹髡Z言編譯成目標(biāo)碼。三、嵌入式SQL與主語言之間的通信 將SQL嵌入到高級語言中混合編程,SQL語句負(fù)責(zé)操縱數(shù)據(jù)庫,高級語言語句負(fù)責(zé)控
3、制流程。這時程序中會含有兩種不同的計算模型的語句,從而需要二者之間建立通信。數(shù)據(jù)庫工作單元與源程序工作單元之間的通信主要包括:(1)向主語言傳遞SQL語句的執(zhí)行狀態(tài)信息,使主語言能夠根據(jù)此信息控制程序流程,主要用SQL通信區(qū)實現(xiàn)(2)主語言向SQL語句提供參數(shù),主要用主變量實現(xiàn)(3)將SQL語句查詢數(shù)據(jù)庫的結(jié)果傳回主語言處理,主要用主變量和游標(biāo)實現(xiàn)三、嵌入SQL的使用規(guī)定(1)在程序中要區(qū)分SQL語句和宿主語言語句 在嵌入式SQL中,為了能夠區(qū)分SQL語句與宿主語言語句,所有的SQL語句都必須加前綴標(biāo)識“EXEC SQL”,并以“END_EXEC”作為語句的結(jié)束標(biāo)志。嵌入式SQL語句的格式如:
4、 EXEC SQL END_EXEC 結(jié)束標(biāo)志在不同的宿主語言中可能是不同的,在C和PASCAL語言程序中規(guī)定結(jié)束標(biāo)志為“;”,而不是“END_EXEC”。三、嵌入式SQL的使用規(guī)定(續(xù))(2)SQL的集合處理方式與宿主語言單記錄處理方式之間的協(xié)調(diào) 由于SQL語句處理的是記錄集合,而宿主語言語句一次只能處理一條記錄,因此需要使用游標(biāo)(Cursor)機制,把集合操作轉(zhuǎn)換為單記錄處理方式。與游標(biāo)有關(guān)的SQL語句如下: 1)游標(biāo)定義語句(DECLARE)。游標(biāo)是與某一查詢結(jié)果相聯(lián)系的符號名,游標(biāo)用SQL的DECLARE語句定義,其格式如下:EXEC SQL DECLARE CURSOR FOREND EXEC游標(biāo)定義語句是一個說明語句,定義中的SELECT并不立即執(zhí)行。三、嵌入式SQL的使用規(guī)定(續(xù)) 2)游標(biāo)打開語句(OPEN)。該語句在執(zhí)行游標(biāo)定義中的SELECT語句,同時游標(biāo)處于活動狀態(tài)。游標(biāo)是一個指針,此時指向查詢結(jié)果的第一行之前。OPEN語句的格式如下:EXEC SQL OPEN END_EXEC三、嵌入式SQL的使用規(guī)定(續(xù)) 3)游標(biāo)讀取數(shù)據(jù)語句(FETCH)。此時游標(biāo)推進(jìn)一行,并把游標(biāo)指向的行(即當(dāng)前行)中的值取出并送到共享變量,其格式如下: EXEC SQL FETCH FROM INTO E
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年裝箱單在應(yīng)對外貿(mào)出口貿(mào)易救濟措施中的策略合同3篇
- 二零二五版國際貿(mào)易特許經(jīng)營合同主體欺詐風(fēng)險管理與合同解除合同3篇
- 二零二五年電子顯示屏廣告租賃合同樣本3篇
- 二零二五版代辦房地產(chǎn)前期開發(fā)手續(xù)與建筑工程質(zhì)量檢測服務(wù)合同3篇
- 二零二五年采棉機駕駛員職業(yè)素養(yǎng)提升與勞動合同3篇
- 二零二五版能源行業(yè)凍庫租賃合同含能源物資儲備協(xié)議3篇
- 二零二五年酒店客房部服務(wù)員勞動合同書3篇
- 天津事業(yè)單位2025年度合同制聘用人員管理規(guī)范3篇
- 二零二五年度裝修合同范本:環(huán)保裝修保障您的生活品質(zhì)6篇
- 二零二五版地產(chǎn)經(jīng)紀(jì)居間合同糾紛處理指南3篇
- 【公開課】同一直線上二力的合成+課件+2024-2025學(xué)年+人教版(2024)初中物理八年級下冊+
- 高職組全國職業(yè)院校技能大賽(嬰幼兒照護(hù)賽項)備賽試題庫(含答案)
- 2024年公安部直屬事業(yè)單位招聘筆試參考題庫附帶答案詳解
- 健康教育工作考核記錄表
- 裝飾工程施工技術(shù)ppt課件(完整版)
- SJG 05-2020 基坑支護(hù)技術(shù)標(biāo)準(zhǔn)-高清現(xiàn)行
- 汽車維修價格表
- 10KV供配電工程施工組織設(shè)計
- 終端攔截攻略
- 藥物外滲處理及預(yù)防【病房護(hù)士安全警示教育培訓(xùn)課件】--ppt課件
評論
0/150
提交評論