下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
2021年國家開放大學電大Oracle數(shù)據(jù)庫編程形考任務(wù)4答案
形考任務(wù)4教學實踐3
創(chuàng)建一個存儲過程,實現(xiàn)在user.tables查詢參數(shù)給出的表名是否存在,并從存儲過程中返
回結(jié)果。
創(chuàng)建一個名稱為sch的數(shù)據(jù)表,表結(jié)構(gòu)如表1所示,將表2中的數(shù)據(jù)插入sch表中。
字段名數(shù)據(jù)類型主鍵外鍵非空唯一自增
idint(10)是否是是否
namevarchar(50)否否是否否
glassvarchar(50)否否是否否
表2:
idnameglass
1xiaomingglassl
2xiaojunglass2
第一步:創(chuàng)建一個sch表,并向sch表中插入表2中的數(shù)據(jù),代碼如下:
mysql>createtablesch
->(
->idint(lO),
->namevarchar(50),
->glassvarchar(SO)
->);
QueryOK,0rowsaffected(0.11sec)
mysql>insertintoschvaluefl/xiaoming'/glass1'),
->(Z/xiaojun'Jglass2');
QueryOK,2rowsaffected(0.05sec)
Records:2Duplicates:0Warnings:0
mysql>descsch;
+------+-------------+------+-----+---------+-------+
|Field|Type|Null|Key|Default|Extra|
+------+-------------+------+-----+---------+-------+
|id|int(10)|YES||NULL|
|name|varchar(50)|YES||NULL|
|glass|varchar(50)|YES||NULL|
3rowsinset(0.00sec)
?1
?2
?3
?4
5
6
?7
?8
?9
?10
?11
?12
?13
?14
?15
?16
?17
?18
?19
?20
?21
?22
通過select*fromsch來查看插入表格的內(nèi)容,SQL語句如下:
idnameglass
1xiaomingglass1
2xiaojunglass2
第二步:創(chuàng)建一個存儲函數(shù)用來統(tǒng)計表sch中的記錄數(shù)。
mysql>createfunctioncount_sch()
->returnsint
->return(selectcount(*)fromsch);
QueryOK,0rowsaffected(0.05sec)
mysql>selectcount_sch();
|count_sch()|
2I
+
1rowinset(0.00sec)
?1
?2
?3
?4
?5
?6
?7
?8
?9
?10
11
?12
創(chuàng)建的存儲函數(shù)名稱為count_sch,通過selectcount_sch()查看函數(shù)執(zhí)行的情況,這個表中只
有兩條記錄,得到的結(jié)果也是兩條記錄,說明函數(shù)成功執(zhí)行。
第三步:創(chuàng)建一個存儲過程,通過調(diào)用存儲函數(shù)的方法來獲取表sch中的記錄數(shù)和sch表中
id的和。
創(chuàng)建一個存儲過程add_id,同時使用前面創(chuàng)建的存儲函數(shù)返回表sch中的記錄數(shù),計算出表
中所有的id之和。代碼如下:
mysql>delimiter//
mysql>createprocedureaddjd(outcountint)
->begin
->declareitmpint;
->declarecurjdcursorforselectidfromsch;
->declareexithandlerfornotfoundclosecurjd;
->selectcount_sch()intocount;
->set@sum=0;
->opencurjd;
->repeat
->fetchcurjdintoitmp;
->ifitmp<10
->thenset@sum=@sum+itmp;
->endif;
->until0endrepeat;
->closecurjd;
->end//
QueryOK,0rowsaffected(0.06sec)
mysql>select@a,@sum//
|@a|@sum|
|NULL|NULL|
1rowinset(0.00sec)
mysql>delimiter;
?1
?2
?3
?4
?5
?6
?7
?8
?9
?10
?11
?12
?13
?14
?15
?16
?17
?18
?19
?20
?21
?22
?23
?24
?25
?26
?27
?28
表sch中只有兩條記錄,所有id的和為3,和預(yù)想的執(zhí)行結(jié)果完全相同。這個存儲過程創(chuàng)建
了一個curjd的光標,使用這個光標來獲取每條記錄的id,使用repeat循環(huán)語句來實現(xiàn)所
有id號相加。
幾個小問題:
1、MySQL存儲過程和存儲函數(shù)有什么區(qū)別?
?本質(zhì)上都是存儲程序。函數(shù)只能通過return語句返回單個值或表對象;存儲過程不
允許執(zhí)行return,但可以通過out參數(shù)返回多個值。
?函數(shù)限制比較多,不能用臨時表,只能用表變量,還有一些函數(shù)都不可用。存儲過
程的限制相對就比較少。
?函數(shù)可以嵌入sql語句中使用,可以在select語句中作為查詢語句中的一個部分調(diào)用,
而存儲過程一般是作為一個獨立的部分來執(zhí)行。
2.存儲過程中的代碼可以改變嗎?
?MySQL還不提供對已存在的存儲過程代碼的修改。如果必須修改存儲過程,就必須
使用drop語句刪除之后再重新編寫,或者創(chuàng)建一個新的存儲過程。
3.存儲過程中可以調(diào)用其他存儲過程嗎?
存儲過程包含用戶定義的sql語句集合,可以使用call語句調(diào)用存儲過程,當然在存儲過程
中也可以使用call語句調(diào)用其他存儲程序,但是不能使用drop語句刪除其他存儲過程。
4.存儲過程的參數(shù)不能與數(shù)據(jù)表中的字段名相同。
在定義存儲過程參數(shù)列表時,應(yīng)注意把參數(shù)名與數(shù)據(jù)庫表中的字段名區(qū)別開,否則將出現(xiàn)無
法預(yù)期的結(jié)果。
5.存儲過程的參數(shù)可以使用中文嗎?
一般情況下,可能會出現(xiàn)存儲過程中傳入中文參數(shù)的情況,例如,
溫馨提示
- 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 家庭教育中的戶外活動對孩子成長的影響
- 嵌入式系統(tǒng)在移動設(shè)備中的節(jié)能設(shè)計挑戰(zhàn)
- 2025至2030年中國管道斜流風機數(shù)據(jù)監(jiān)測研究報告
- 鐵路工程板梁吊裝協(xié)議
- 校園體育空間功能多樣性與利用效率研究報告
- 2025至2030年中國半自動玻璃切割流水線數(shù)據(jù)監(jiān)測研究報告
- 2025年中國高效復(fù)合緩蝕阻垢劑市場調(diào)查研究報告
- 2025年中國防水圍布市場調(diào)查研究報告
- 2025年中國祛痘無痕霜市場調(diào)查研究報告
- 旅游景區(qū)物業(yè)承租居間協(xié)議
- 第二章 運營管理戰(zhàn)略
- 《三本白皮書》全文內(nèi)容及應(yīng)知應(yīng)會知識點
- 專題14 思想方法專題:線段與角計算中的思想方法壓軸題四種模型全攻略(解析版)
- 醫(yī)院外來器械及植入物管理制度(4篇)
- 圖像識別領(lǐng)域自適應(yīng)技術(shù)-洞察分析
- 港口與港口工程概論
- 《念珠菌感染的治療》課件
- 新概念英語第二冊考評試卷含答案(第49-56課)
- 商業(yè)倫理與企業(yè)社會責任(山東財經(jīng)大學)智慧樹知到期末考試答案章節(jié)答案2024年山東財經(jīng)大學
- 【奧運會獎牌榜預(yù)測建模實證探析12000字(論文)】
- (完整版)譯林版英語詞匯表(四年級下)
評論
0/150
提交評論