下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
2021年國家開放大學(xué)電大Oracle數(shù)據(jù)庫編程形考任務(wù)4答案
形考任務(wù)4教學(xué)實(shí)踐3
創(chuàng)建一個(gè)存儲(chǔ)過程,實(shí)現(xiàn)在user.tables查詢參數(shù)給出的表名是否存在,并從存儲(chǔ)過程中返
回結(jié)果。
創(chuàng)建一個(gè)名稱為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)建一個(gè)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)建一個(gè)存儲(chǔ)函數(shù)用來統(tǒng)計(jì)表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)建的存儲(chǔ)函數(shù)名稱為count_sch,通過selectcount_sch()查看函數(shù)執(zhí)行的情況,這個(gè)表中只
有兩條記錄,得到的結(jié)果也是兩條記錄,說明函數(shù)成功執(zhí)行。
第三步:創(chuàng)建一個(gè)存儲(chǔ)過程,通過調(diào)用存儲(chǔ)函數(shù)的方法來獲取表sch中的記錄數(shù)和sch表中
id的和。
創(chuàng)建一個(gè)存儲(chǔ)過程add_id,同時(shí)使用前面創(chuàng)建的存儲(chǔ)函數(shù)返回表sch中的記錄數(shù),計(jì)算出表
中所有的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é)果完全相同。這個(gè)存儲(chǔ)過程創(chuàng)建
了一個(gè)curjd的光標(biāo),使用這個(gè)光標(biāo)來獲取每條記錄的id,使用repeat循環(huán)語句來實(shí)現(xiàn)所
有id號(hào)相加。
幾個(gè)小問題:
1、MySQL存儲(chǔ)過程和存儲(chǔ)函數(shù)有什么區(qū)別?
?本質(zhì)上都是存儲(chǔ)程序。函數(shù)只能通過return語句返回單個(gè)值或表對(duì)象;存儲(chǔ)過程不
允許執(zhí)行return,但可以通過out參數(shù)返回多個(gè)值。
?函數(shù)限制比較多,不能用臨時(shí)表,只能用表變量,還有一些函數(shù)都不可用。存儲(chǔ)過
程的限制相對(duì)就比較少。
?函數(shù)可以嵌入sql語句中使用,可以在select語句中作為查詢語句中的一個(gè)部分調(diào)用,
而存儲(chǔ)過程一般是作為一個(gè)獨(dú)立的部分來執(zhí)行。
2.存儲(chǔ)過程中的代碼可以改變嗎?
?MySQL還不提供對(duì)已存在的存儲(chǔ)過程代碼的修改。如果必須修改存儲(chǔ)過程,就必須
使用drop語句刪除之后再重新編寫,或者創(chuàng)建一個(gè)新的存儲(chǔ)過程。
3.存儲(chǔ)過程中可以調(diào)用其他存儲(chǔ)過程嗎?
存儲(chǔ)過程包含用戶定義的sql語句集合,可以使用call語句調(diào)用存儲(chǔ)過程,當(dāng)然在存儲(chǔ)過程
中也可以使用call語句調(diào)用其他存儲(chǔ)程序,但是不能使用drop語句刪除其他存儲(chǔ)過程。
4.存儲(chǔ)過程的參數(shù)不能與數(shù)據(jù)表中的字段名相同。
在定義存儲(chǔ)過程參數(shù)列表時(shí),應(yīng)注意把參數(shù)名與數(shù)據(jù)庫表中的字段名區(qū)別開,否則將出現(xiàn)無
法預(yù)期的結(jié)果。
5.存儲(chǔ)過程的參數(shù)可以使用中文嗎?
一般情況下,可能會(huì)出現(xiàn)存儲(chǔ)過程中傳入中文參數(shù)的情況,例如,
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 商業(yè)步行街景觀路燈施工合同
- 瑜伽教練保姆合同模板
- 職業(yè)體驗(yàn)?zāi)攴b租賃合同模板
- 城市防噪系統(tǒng)防水涂料施工合同
- 婚慶用品租賃合同范本
- 高爐建設(shè)投資分析合同
- 鄭州二手房買賣合同風(fēng)險(xiǎn)防范
- 外語培訓(xùn)機(jī)構(gòu)教師合同
- 住宅建筑地暖安裝合同樣本
- 電子產(chǎn)品零售倉儲(chǔ)協(xié)議
- 粉末銷售合同范例
- 2024-2025學(xué)年人教版生物學(xué)八年級(jí)上冊(cè)期末復(fù)習(xí)練習(xí)題(含答案)
- 大學(xué)生職業(yè)生涯規(guī)劃與就業(yè)創(chuàng)業(yè)指導(dǎo)知到智慧樹章節(jié)測(cè)試課后答案2024年秋四川水利職業(yè)技術(shù)學(xué)院
- 檔案管理基本知識(shí)課件
- 高二語文上學(xué)期期末考點(diǎn)大串講(統(tǒng)編版選擇性必修上冊(cè)+中冊(cè))專題01 信息類文本閱讀(知識(shí)清單)
- 浙江強(qiáng)基聯(lián)盟2024年12月高三聯(lián)考?xì)v史試題(含答案)
- 中建地下防水施工方案
- 2025年上半年廈門市外事翻譯護(hù)照簽證中心招考易考易錯(cuò)模擬試題(共500題)試卷后附參考答案
- 名師工作室建設(shè)與管理方案
- 2024年小學(xué)體育新課標(biāo)測(cè)評(píng)考試題庫(含答案)
- 新《安全生產(chǎn)法》安全培訓(xùn)
評(píng)論
0/150
提交評(píng)論